java 数据库基本操作 z,VXH ?.Zo
1、java数据库操作基本流程 3@<m/%
2、几个常用的重要技巧: 9mpQusM
可滚动、更新的记录集 [yRqSB
批量更新 lHu/pSu@k
事务处理 9(bbV5}
GW9,%}l^;
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 'n?"f |G
1、取得数据库连接 w}29#F\]R
1)用DriverManager取数据库连接 \`8F.oZ^)
例子 {4%ddJn[.)
String className,url,uid,pwd; E>"SC\#7
className = "oracle.jdbc.driver.OracleDriver"; ~0vNs2D,S
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; &3*r-9BZ
uid = "system"; R!rMrWX
pwd = "manager"; TdoH((nY
Class.forName(className); cL"Ral-qB
Connection cn = DriverManager.getConnection(url,uid,pwd); 5+)_d%v=6!
2)用jndi(java的命名和目录服务)方式 O /h1ew
例子 /4+*!X
String jndi = "jdbc/db"; CKDg3p';
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); y! j>_m){w
DataSource ds = (DataSource) ctx.lookup(jndi); 9Lqz:4}
Connection cn = ds.getConnection(); ,yi@?lc
多用于jsp中 Pfm B{
2、执行sql语句 lI5>d(6p
1)用Statement来执行sql语句 rhN"#?
String sql; /]nrxT
Statement sm = cn.createStatement(); ?X7nM)
sm.executeQuery(sql); // 执行数据查询语句(select) >.REg[P
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); uHTm
2)用PreparedStatement来执行sql语句 gOaK7A
String sql; 7re4mrC
sql = "insert into user (id,name) values (?,?)"; X0KUnxw
PreparedStatement ps = cn.prepareStatement(sql); ;!m_RQPFF
ps.setInt(1,xxx); 5%DHF-W)
ps.setString(2,xxx); <(us(zbk]
... \/r]Ra
ResultSet rs = ps.executeQuery(); // 查询 =e6!U5
f
int c = ps.executeUpdate(); // 更新 A}1:fw\Fn3
#|Je%t}~
3、处理执行结果 `oE.$~'
查询语句,返回记录集ResultSet fl*49-d
更新语句,返回数字,表示该更新影响的记录数 Ba
n^wX
ResultSet的方法 N/E=-&E8
1、next(),将游标往后移动一行,如果成功返回true;否则返回false ]oC7{OoX
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 'qidorT>N
U,aMv[Z B
4、释放连接 y!\q', F
cn.close(); qmnW
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection ,w_C~XN$t
g;y*F;0@
可滚动、更新的记录集 5WtI.7r
1、创建可滚动、更新的Statement &hzr(v~;
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY);
1_LGlu~&
该Statement取得的ResultSet就是可滚动的 C,{ Ekbg
2、创建PreparedStatement时指定参数 )/{~&LU
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); A{52T]9X
ResultSet.absolute(9000); 9O:-q[K**
批量更新
5)M#hx%]#
1、Statement o^BX:\}
Statement sm = cn.createStatement(); Vb~;"WABo
sm.addBatch(sql1); l+O\oD?-
sm.addBatch(sql2); b28C(
... AE%zqvp>
sm.executeBatch() ' PmBNT
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 ~hU^5R-%
2、PreparedStatement 'W[Nr
PreparedStatement ps = cn.preparedStatement(sql); CWnRRZ}r
{ JZD&u6tB
ps.setXXX(1,xxx); c$)!02
... zM'2opiUY
ps.addBatch(); gac/%_-HH7
} 'Ub\8<HfJU
ps.executeBatch(); E^m2:J]G
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 (DTkK5/%
IPnx5#eB
事务的处理 Ly6) ,[q~
1、关闭Connection的自动提交 _Tma1~Gq
cn.setAutoCommit(false); 0O?!fd n
2、执行一系列sql语句 bj 0-72V
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close W-vEh
Statement sm ; X""}]@B9z
sm = cn.createStatement(insert into user...); rf$eg
sm.executeUpdate(); bw[K^/
sm.close();
~&_BT`a
sm = cn.createStatement("insert into corp...); `I5So-^&z
sm.executeUpdate(); 5VlF\-
sm.close(); V j_z"t7q
3、提交 T'VKZ5W
cn.commit(); TK%MVL TK
4、如果发生异常,那么回滚 5U(ry6fI=
cn.rollback();