java 数据库基本操作 kll!tT-N-
1、java数据库操作基本流程 %z@ Z^Jv
2、几个常用的重要技巧: RBf#5VjOG!
可滚动、更新的记录集 qzNb\y9G
批量更新 n',X,P0
事务处理 &zy%_U2%
_1E c54D
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 6vbKKn`ST
1、取得数据库连接 QnOgF 3t
1)用DriverManager取数据库连接 BH {z]a
例子 ~xxq.rL"
String className,url,uid,pwd; B,%6sa~I
className = "oracle.jdbc.driver.OracleDriver"; sc+%v1Y#}
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; 69r%b7#
uid = "system"; D%o(HS\E
pwd = "manager"; ;6PU
Class.forName(className); *B!Ox}CI.L
Connection cn = DriverManager.getConnection(url,uid,pwd); W8^A{l4
2)用jndi(java的命名和目录服务)方式 9*s8%pL
例子 THQ #zQ-
String jndi = "jdbc/db"; VC/n}7p
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); ek<B= F
DataSource ds = (DataSource) ctx.lookup(jndi); 5r
4~vK
Connection cn = ds.getConnection(); wicsf<]
多用于jsp中 eGQ4aQhi
2、执行sql语句 /~'C!so[v
1)用Statement来执行sql语句 Hb*Z_s
String sql; heIys.p
Statement sm = cn.createStatement(); ]>)shH=Yx
sm.executeQuery(sql); // 执行数据查询语句(select) @Ik5BT
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); 5fk
A?Ecqq
2)用PreparedStatement来执行sql语句 0-uj0"r`
String sql; _-RqkRI
sql = "insert into user (id,name) values (?,?)"; l=XZBe*[g'
PreparedStatement ps = cn.prepareStatement(sql); Y<W9LF
ps.setInt(1,xxx); YM;ro5_KF
ps.setString(2,xxx); =Ks&m4
... A nl1+
ResultSet rs = ps.executeQuery(); // 查询 KB~[nZs7
int c = ps.executeUpdate(); // 更新 -x6_HibbD
7#"NKxb
3、处理执行结果 6
DQOar>d
查询语句,返回记录集ResultSet 83vZRQw
更新语句,返回数字,表示该更新影响的记录数 2&S^\kf
ResultSet的方法 Jk}3c>^D
1、next(),将游标往后移动一行,如果成功返回true;否则返回false LkYcFD
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 ?yAb=zI1b
90+Vw`Gz=
4、释放连接 (^B1Kt!<
cn.close(); :K~@JlJd
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection ?84f\<"
QyTNV
可滚动、更新的记录集 m$[:J
1、创建可滚动、更新的Statement 7<70\6
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); OcF_x/#
该Statement取得的ResultSet就是可滚动的 FDuA5At
2、创建PreparedStatement时指定参数 5w>TCx
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); @dK_w'W
ResultSet.absolute(9000); z<t2yh(DF
批量更新 ).,twf58
1、Statement lv]U)p
Statement sm = cn.createStatement(); R $<{"b
sm.addBatch(sql1); Jityb}Z"
sm.addBatch(sql2); (&*Bl\YoX
... h-(NWxK+
sm.executeBatch() P2ySjgd
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 .&]3wB~
2、PreparedStatement >N!
Xey
PreparedStatement ps = cn.preparedStatement(sql); am5;B`}q
{ s'tXb=!HO
ps.setXXX(1,xxx); D`41\#ti
... ]Y$Wv9S6
ps.addBatch(); 2vUcSKG7
} R+0fs$su
ps.executeBatch(); dh{py
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 '$yy
A-vYy1,'
事务的处理 ]c_lNHssmq
1、关闭Connection的自动提交 ,e OZv=:
cn.setAutoCommit(false); #r>)A
2、执行一系列sql语句 _G4U
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close Q!-"5PX
Statement sm ; [Ti' X#
sm = cn.createStatement(insert into user...); }<2|6 {
sm.executeUpdate(); oVUsI,8
sm.close(); ?zsRs?rc0
sm = cn.createStatement("insert into corp...); -*&aE~Cs
sm.executeUpdate(); 6U|"d[
sm.close(); Xq"9TYf$
3、提交 XOS^&;
cn.commit(); Y/mf Bkh
4、如果发生异常,那么回滚 JeVbFZ8
cn.rollback();