java 数据库基本操作 |es?;s'
1、java数据库操作基本流程 Ki$MpA3j
2、几个常用的重要技巧: &-Gqdnc
可滚动、更新的记录集 Pama#6?OPh
批量更新 qGB{7-r u
事务处理 iW%I|&
Kzm+GW3o[
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 AicBSqUke
1、取得数据库连接 3yU.& k
1)用DriverManager取数据库连接 (mTE;s(
例子 ][+#;avU
String className,url,uid,pwd; 5A3xVN=
className = "oracle.jdbc.driver.OracleDriver"; 26I_YL,S
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; W_\5nF
uid = "system"; c|B.n]Z
pwd = "manager"; UU;(rS/
Class.forName(className); J\:R|KaP<p
Connection cn = DriverManager.getConnection(url,uid,pwd); 7WkB>cn
2)用jndi(java的命名和目录服务)方式 Vk
K
例子 c4^ks&)'
String jndi = "jdbc/db"; g"p%C:NN
Context ctx = (Context) new InitialContext().lookup("java:comp/env");
4~Vx3gEV:
DataSource ds = (DataSource) ctx.lookup(jndi); ^6MU
0Q2
Connection cn = ds.getConnection(); p'*>vk
多用于jsp中 G\Cp7:j}
2、执行sql语句 Eg#K.5hJ
1)用Statement来执行sql语句 wnEyl[ac
String sql; "$+Jnc!!
Statement sm = cn.createStatement(); lm-dW'7&
sm.executeQuery(sql); // 执行数据查询语句(select) P3x= 8_#
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); '
V^6XI
2)用PreparedStatement来执行sql语句 'MUv5Th
String sql; 4ew"
%Cs*
sql = "insert into user (id,name) values (?,?)"; N~goI#4
PreparedStatement ps = cn.prepareStatement(sql); t^R][Ay&
ps.setInt(1,xxx); bnq;)>&
ps.setString(2,xxx); nYR#
... V3Q+s8OIF
ResultSet rs = ps.executeQuery(); // 查询 bMg(B-uF7
int c = ps.executeUpdate(); // 更新
-D
!;Yg/'vD-
3、处理执行结果 cl=EA6P\X
查询语句,返回记录集ResultSet cl[BF'.H
更新语句,返回数字,表示该更新影响的记录数 5\5/
ResultSet的方法 XHK<AO^
1、next(),将游标往后移动一行,如果成功返回true;否则返回false }Jy8.<Gd^
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 AS'R?aX|C
/YW>*?"N
4、释放连接 p*4':TFuD;
cn.close(); :dl]h&C^
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection C*)3e*T*
GP!?^r:en
可滚动、更新的记录集 ^84G%)`&
1、创建可滚动、更新的Statement U@_dm/;0&
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); EUD~CZhS"k
该Statement取得的ResultSet就是可滚动的 ,
pDnRRJ!
2、创建PreparedStatement时指定参数 %p^wZtm
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); Xx."$l
ResultSet.absolute(9000); :DrWq{4
批量更新 nBjqTud
1、Statement [R(`W#W
Statement sm = cn.createStatement(); Y!~49<;
sm.addBatch(sql1); +7D|4
sm.addBatch(sql2); 0=@?ob7
... OE_XCZ!5P
sm.executeBatch() S!jTyY7e
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 /32Fy`KV
2、PreparedStatement X@+{5%
PreparedStatement ps = cn.preparedStatement(sql); A-Sv;/yD_
{ L-jJg,eY
ps.setXXX(1,xxx); h58`XH
... Zd^rNHhA
ps.addBatch(); s@&`f{
} rdl;M>0@
ps.executeBatch(); sT 3^hY7
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 dpAjR
Su
586;\
事务的处理 8n#HFJ~
1、关闭Connection的自动提交 PWaw]*dFmy
cn.setAutoCommit(false); A -H&
2、执行一系列sql语句 .b3Qfxc>
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close nrL9
E'F'
Statement sm ; NPhhD&W_
sm = cn.createStatement(insert into user...); 3KRd
sm.executeUpdate(); ?i7%x,g(Z
sm.close(); Y>|B;Kj0(
sm = cn.createStatement("insert into corp...);
?]|\4]zV
sm.executeUpdate(); / ;$#d}R
sm.close(); {C 6=[
3、提交 CJ/X}hi,
cn.commit(); x5,++7Tz
4、如果发生异常,那么回滚 9_# >aOqL
cn.rollback();