java 数据库基本操作 7Kf}O6nE
1、java数据库操作基本流程 LJQJ\bT?
2、几个常用的重要技巧: & ,L9O U
可滚动、更新的记录集 xx8U$,Ng
批量更新 :reTJQwr
事务处理 Z$'IBv
]gEhE
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 $-vo}k%M
1、取得数据库连接 )1F<6R
1)用DriverManager取数据库连接 'C?NJ~MN
例子 Qw)9r{f
String className,url,uid,pwd; bJ3(ckhq
className = "oracle.jdbc.driver.OracleDriver"; M>l^%`
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; R,Oe$J<
uid = "system"; {6
.o=EyM{
pwd = "manager"; Zzj0\?Ul
Class.forName(className); }
/:\U
p
Connection cn = DriverManager.getConnection(url,uid,pwd); Yrn"saVc,
2)用jndi(java的命名和目录服务)方式 A6UO0lyu
例子 uDayBaR
String jndi = "jdbc/db"; ^O6*e]C$
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); !/I0i8T
DataSource ds = (DataSource) ctx.lookup(jndi); RT*5d;l0
Connection cn = ds.getConnection(); >V;,#5F_
多用于jsp中 qv+R:YYOq
2、执行sql语句 Bjj<\8^M
1)用Statement来执行sql语句 UUtbD&\
String sql; 4]&<?"LSK
Statement sm = cn.createStatement(); P7GRSjG
sm.executeQuery(sql); // 执行数据查询语句(select) -_8*41
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); c3xl9S,5
2)用PreparedStatement来执行sql语句 H+ZSPHs
String sql; >SCGK_Cr2
sql = "insert into user (id,name) values (?,?)"; +=P@HfVfiq
PreparedStatement ps = cn.prepareStatement(sql); UAYd?r
ps.setInt(1,xxx); rwqv V^
ps.setString(2,xxx); 9dKul,c
... KMjg;!y
ResultSet rs = ps.executeQuery(); // 查询 RKTb'3H
int c = ps.executeUpdate(); // 更新 B0)]s<<
`M@Ak2gcR+
3、处理执行结果 0 bSA_
查询语句,返回记录集ResultSet cF+ X,]=6
更新语句,返回数字,表示该更新影响的记录数 '$m7ft}
ResultSet的方法 =-jD~rN4;P
1、next(),将游标往后移动一行,如果成功返回true;否则返回false N$ alUx*
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 O/OiQ^T
py<_HyJ
4、释放连接 \2X$C#8E
cn.close(); n:#TOU1ix<
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection F0dI/+
3$p#;a:=n
可滚动、更新的记录集 *l>0t]5YH
1、创建可滚动、更新的Statement i~yX tya
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); (#Mp 5C'X
该Statement取得的ResultSet就是可滚动的 eD;6okdP
2、创建PreparedStatement时指定参数 }e{qW
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); K|^wc$
ResultSet.absolute(9000); TKI$hc3|L
批量更新 D`o<,Y
1、Statement 3y`F<&sA
Statement sm = cn.createStatement(); .BZVX=x
sm.addBatch(sql1); FGanxv@15
sm.addBatch(sql2); 3h=8"lRc
... "pvZ,l>8f
sm.executeBatch() z,Lzgh
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 WeT* C
2、PreparedStatement M}F~_S0h
PreparedStatement ps = cn.preparedStatement(sql); }ot"Sx\.
{ d@kc[WLD^
ps.setXXX(1,xxx); wNQqfqZ
... G=d(*+&
B
ps.addBatch(); 5nLDj:C~
} jBtj+TL8
ps.executeBatch(); UpUp8%fCU
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 <'m6^]:
clDHTj=~
事务的处理 :nGMtF
1、关闭Connection的自动提交 M] EsS^/X
cn.setAutoCommit(false); lrEj/"M
2、执行一系列sql语句 \8b6\qF/\
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close >-cfZ9 {!
Statement sm ; J !#Zi#8sF
sm = cn.createStatement(insert into user...);
'3,\@4
sm.executeUpdate(); Ex(3D[WmMW
sm.close(); \M+L3*W
sm = cn.createStatement("insert into corp...); 'fW#7W
sm.executeUpdate(); Ka-p& Uv1<
sm.close(); `~F5wh~
3、提交 |:q/Dt@
cn.commit(); r6.N4eW.L
4、如果发生异常,那么回滚 _PXdzeI.
cn.rollback();