java 数据库基本操作 ItHKpTer
1、java数据库操作基本流程 I5>HB;Q
2、几个常用的重要技巧: W}+Q!T=
可滚动、更新的记录集 O[3J Px
批量更新 &6FRw0GX
事务处理 =:v\}/
C78YHjy
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 jwyJ=W-
1、取得数据库连接 BgJ;\NV
1)用DriverManager取数据库连接 J %jfuj
例子 AnG/A!G
String className,url,uid,pwd; AF ZHS\
className = "oracle.jdbc.driver.OracleDriver"; [Nr6qxWg
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; V'
"p
a
uid = "system"; ]IXKoJUf
pwd = "manager"; 1wuLw Ad
Class.forName(className); 1C^6'9o
Connection cn = DriverManager.getConnection(url,uid,pwd); D$;mur'
2)用jndi(java的命名和目录服务)方式 j\f;zb?F
例子 K=M5d^K<E
String jndi = "jdbc/db"; Yq4_ss'nB
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); G<9MbMG
DataSource ds = (DataSource) ctx.lookup(jndi); FgrOZI;_
Connection cn = ds.getConnection(); 7&/iuP$.
多用于jsp中 7=u\D
2、执行sql语句 DoX#+
07u4
1)用Statement来执行sql语句 =et=X_3-
String sql; ]zmY]5
Statement sm = cn.createStatement(); z(iB$;M
sm.executeQuery(sql); // 执行数据查询语句(select) \evK.i*KfA
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); b)(#/}jMkD
2)用PreparedStatement来执行sql语句 @G^]kDFM{
String sql; ;S"^O
AM
sql = "insert into user (id,name) values (?,?)"; \A*#a9"
PreparedStatement ps = cn.prepareStatement(sql); mWsVOf>g
ps.setInt(1,xxx); POfvs]
ps.setString(2,xxx); '{QbjG%<P
... 4Wk/^*?
ResultSet rs = ps.executeQuery(); // 查询 6Y)'p
.+g
int c = ps.executeUpdate(); // 更新 [ahD%UxO5
K SDo)7`
3、处理执行结果 ^F5[2<O/!
查询语句,返回记录集ResultSet aRdk^|}
更新语句,返回数字,表示该更新影响的记录数 #,Fk
ResultSet的方法 ]Hc`<P
1、next(),将游标往后移动一行,如果成功返回true;否则返回false o?b$}Qrl
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 P-ys$=
-wvrc3F
4、释放连接 8k2prv^
cn.close(); zIf/j k
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection J1YP-:
yDWzsA/X
可滚动、更新的记录集 zK(9k0+s
1、创建可滚动、更新的Statement (ST/>")L
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); M-,vX15S
该Statement取得的ResultSet就是可滚动的 Z<;<!+,
2、创建PreparedStatement时指定参数 fMlxtj+5
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); rg"W1m[k
ResultSet.absolute(9000); SWY?0Pu
批量更新 QB'-`GwL
1、Statement b4Zkj2L
Statement sm = cn.createStatement(); HY~\e|o
sm.addBatch(sql1); 4M*UVdJ;
sm.addBatch(sql2); b|u4h9
... I{;s.2
sm.executeBatch() vK!,vKa.
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 F/tBr%RV
2、PreparedStatement 4gG&u33RrE
PreparedStatement ps = cn.preparedStatement(sql); *$Aneq0f
{ K!7o#"GM
ps.setXXX(1,xxx); ':R)i.TS
... iSUn}%YFz!
ps.addBatch(); /PE3>"|w E
} .wtb7U;7
ps.executeBatch(); #yFDC@gH1
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 id\0yRBt
8OqG{jmG
事务的处理 n AQB
1、关闭Connection的自动提交 *JZU
0Xb
cn.setAutoCommit(false); U`ey7
2、执行一系列sql语句 Z=|:D,&
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close t~)w921>
Statement sm ; wr~# rfH
sm = cn.createStatement(insert into user...); MIub^ $<C
sm.executeUpdate(); UN'hnqC
sm.close(); CtTG`)"|
sm = cn.createStatement("insert into corp...); gs_"H
sm.executeUpdate(); Q6Vy}
sm.close(); T#DJQ"$
3、提交 mLd=+&M
cn.commit(); k`62&"T
4、如果发生异常,那么回滚 ;gcQ9L
cn.rollback();