java 数据库基本操作 :aMp,DfM]P
1、java数据库操作基本流程 :6Sb3w5h
2、几个常用的重要技巧: %i`YJ
可滚动、更新的记录集 Dz&<6#L<
批量更新 q,eXH8 x
事务处理 (?zZvW8
lb`2a3W/
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 y8\4TjS1
1、取得数据库连接 V~qlg1h
1)用DriverManager取数据库连接 cx(b5Z
例子 0)3*E)g{
String className,url,uid,pwd; agW#"9]WM
className = "oracle.jdbc.driver.OracleDriver"; zf^F.wW
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; x^]1m%
uid = "system"; 7ip(-0
pwd = "manager"; ?28aEX_w
Class.forName(className); 4S#q06=Xe
Connection cn = DriverManager.getConnection(url,uid,pwd); !Pb39[f
2)用jndi(java的命名和目录服务)方式 'D;'Pr]
例子 }[I|oV5*+&
String jndi = "jdbc/db"; )haHI)xR
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); kzb1iBe 6m
DataSource ds = (DataSource) ctx.lookup(jndi); #$9rH
2zd
Connection cn = ds.getConnection(); j!<RY>u
多用于jsp中 v:$Y
|mh
2、执行sql语句 18U
CZ;)>
1)用Statement来执行sql语句 :j0r~*z-
String sql; ZN?UkFnE
Statement sm = cn.createStatement(); T5di#%: s
sm.executeQuery(sql); // 执行数据查询语句(select) FqK2[]8
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); $:MO/Suz{
2)用PreparedStatement来执行sql语句 &O.S ;b*+
String sql; 1 ~#p3)B
sql = "insert into user (id,name) values (?,?)"; nANoy6z:
PreparedStatement ps = cn.prepareStatement(sql); {CR'Z0
ps.setInt(1,xxx); O~AOZ^a:2
ps.setString(2,xxx); \
>(;t#>
... $?u ^hMU=
ResultSet rs = ps.executeQuery(); // 查询 2 9=L7
int c = ps.executeUpdate(); // 更新 3#Hx^H
URD<KIN>
3、处理执行结果 Zj8aD-1]U^
查询语句,返回记录集ResultSet ul$YV9[\
更新语句,返回数字,表示该更新影响的记录数 ,fwN_+5
ResultSet的方法 ?pv}~>
1、next(),将游标往后移动一行,如果成功返回true;否则返回false DHV#PLbN$
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 T9+ ?A
l
+}@HtjM
4、释放连接 VJeN
m3WNb
cn.close(); cHMS[.=;
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection Y+tXWN"8
O2Mo ~}
可滚动、更新的记录集 bu#}`/\_
1、创建可滚动、更新的Statement (U |[C*
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); UC34AKm
该Statement取得的ResultSet就是可滚动的 Py8<db%
2、创建PreparedStatement时指定参数 |0mVK`
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); X|7Y|0o
ResultSet.absolute(9000); 5E/z.5 q
批量更新 `MtPua\_
1、Statement l&4TfzkY
Statement sm = cn.createStatement(); #`mo5
sm.addBatch(sql1); 4yH=dl4=44
sm.addBatch(sql2); FPu"/4v&
... =,~h]_\_
sm.executeBatch() :,=no>mMx
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 v&B*InR?+
2、PreparedStatement /0mbG!Ac
PreparedStatement ps = cn.preparedStatement(sql); +BRmqJ3
{ HX{O@
ps.setXXX(1,xxx); PQRh5km
... YGObTIGJvf
ps.addBatch(); oP".>g-.
} [2!K 6
ps.executeBatch(); 2c
<Qh=
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 %jY/jp=R
n@xDFa
事务的处理 j#b?P=|l
1、关闭Connection的自动提交 :hG?} [-2
cn.setAutoCommit(false); $3sS&i<
2、执行一系列sql语句 !0~$u3[b
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close Fr)G
h>
Statement sm ; +QIM~tt)
sm = cn.createStatement(insert into user...); por[p\ M.
sm.executeUpdate(); ]iuM2]
sm.close(); xaWm wsym
sm = cn.createStatement("insert into corp...);
P.RlozF5;
sm.executeUpdate(); {@9y%lmrh
sm.close(); 0=;jGh}|i
3、提交 ++:v O
cn.commit(); B8_w3;x
4、如果发生异常,那么回滚 5[M?O4mi
cn.rollback();