java 数据库基本操作 `V[ hE
r|
1、java数据库操作基本流程 EY :EpVin
2、几个常用的重要技巧: M?ElD1#Z
可滚动、更新的记录集 xaIe7.Z"xo
批量更新 ciPq@kMV
事务处理 FlH=Pqc
.MxMBrM
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 7:C2xC
1、取得数据库连接 ;Qlb].td
1)用DriverManager取数据库连接 p,)pz_M
例子 Ao *{#z
String className,url,uid,pwd; 'GZ,
className = "oracle.jdbc.driver.OracleDriver"; !-B|x0fs
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; *+ O
uid = "system"; #t">tL
pwd = "manager"; )Z`OkkabnD
Class.forName(className); evyA#~o
Connection cn = DriverManager.getConnection(url,uid,pwd); lI[O!VuKc
2)用jndi(java的命名和目录服务)方式 ,z$U=uo
例子 z&|sks7
String jndi = "jdbc/db"; '&y+,2?;Y[
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); rAu@`H?
DataSource ds = (DataSource) ctx.lookup(jndi); \#'m([<e
Connection cn = ds.getConnection(); hl+
T
多用于jsp中
!h*F58
2、执行sql语句 wA%,_s/U
1)用Statement来执行sql语句 dM5N1$1,
String sql; pA5X<)~
Statement sm = cn.createStatement(); jpfFJon)w
sm.executeQuery(sql); // 执行数据查询语句(select) 8{-bG8L> 5
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); !R$t>X
2)用PreparedStatement来执行sql语句 3.04Toq!
String sql; [sG!|@r
sql = "insert into user (id,name) values (?,?)"; HD}3mP
PreparedStatement ps = cn.prepareStatement(sql); *C^`+*}OE$
ps.setInt(1,xxx); *3y:Wv T>
ps.setString(2,xxx); f87lm*wZ
... -s6;IoG/
ResultSet rs = ps.executeQuery(); // 查询 Snas:#B!
int c = ps.executeUpdate(); // 更新 g6q67m<h
TUR2|J@n
3、处理执行结果 2{-'`lfM%
查询语句,返回记录集ResultSet y]%Io]!d
更新语句,返回数字,表示该更新影响的记录数 )G$0:-J-
ResultSet的方法 M7AUY#)
1、next(),将游标往后移动一行,如果成功返回true;否则返回false !r_2b! dy
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 t. kOR<
}{) >aJ
4、释放连接 :YN,cI d*
cn.close(); %R*-oQ1T
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection 6\/(TW&
&28%~&L
可滚动、更新的记录集 ^@xn 3zJ
1、创建可滚动、更新的Statement f(*^zga,
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); )}R
w@70L-
该Statement取得的ResultSet就是可滚动的 E`UEl$($
2、创建PreparedStatement时指定参数 nOUF<DNQ
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); !\1Pu|
ResultSet.absolute(9000); k*= #XbX
批量更新 @RI\CqFHR
1、Statement ~YrO>H` B
Statement sm = cn.createStatement(); 'sTMUPg`
sm.addBatch(sql1); *8xMe
sm.addBatch(sql2);
1"} u51
... 8|\?imOp\[
sm.executeBatch() 25jgM!QBXF
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 X\LiV{c
2、PreparedStatement | D,->k
PreparedStatement ps = cn.preparedStatement(sql); i}e OWi
{ 1mz72K
ps.setXXX(1,xxx); By}>h6`[
... BjCg!6`XF
ps.addBatch(); x]jJ
} X/`M'8v.%
ps.executeBatch(); *`wgqin
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 A;C)#Q/
G8!* &vR/
事务的处理 7
a_99?J
1、关闭Connection的自动提交 \TXCq@
cn.setAutoCommit(false); %u02KmV.
2、执行一系列sql语句 5Qgh\4
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close ~i/K7qZ
Statement sm ; .Zv uhOn^
sm = cn.createStatement(insert into user...); Q96^rjY
sm.executeUpdate(); iwT
PJGK|
sm.close(); VTvNn
sm = cn.createStatement("insert into corp...); a/H|/CB3
sm.executeUpdate(); rnTjw
"%
sm.close(); $y+Bril5W
3、提交 \ POQeZ
cn.commit(); X=i",5;
4、如果发生异常,那么回滚 ]Br6!U4~
cn.rollback();