java 数据库基本操作 "Dy&`
1、java数据库操作基本流程 :x;D- kZ
2、几个常用的重要技巧: =l_eliM/
可滚动、更新的记录集 h?CNChRJs
批量更新 U O[p
事务处理 89 lPeFQ`
v=W%|iZ
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 Y<M}'t
1、取得数据库连接 @B[=`9KF[
1)用DriverManager取数据库连接 hpw;w}m
例子 E]7G4
String className,url,uid,pwd; <4>6k7W
className = "oracle.jdbc.driver.OracleDriver"; eq/s8]uM
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; ',CcL N
uid = "system"; \tQi7yj4
pwd = "manager"; a<HM|dcst
Class.forName(className); +
6}FUi!"e
Connection cn = DriverManager.getConnection(url,uid,pwd); g1}RA@9
2)用jndi(java的命名和目录服务)方式 x,1&ml5
例子 p<J/J.E
String jndi = "jdbc/db"; Rn TPU`
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); |X_yL3`Zb
DataSource ds = (DataSource) ctx.lookup(jndi); {<|0M%v
Connection cn = ds.getConnection(); '<@ PgO~
多用于jsp中 i\PN
2、执行sql语句 ?}Mv5SO
1)用Statement来执行sql语句 '~a!~F~>
String sql; Cf10 ud
Statement sm = cn.createStatement(); D #A9
sm.executeQuery(sql); // 执行数据查询语句(select) :`uo]B"
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); #6YNgJNk
2)用PreparedStatement来执行sql语句 %b_zUFHPp
String sql; hxtu^E/
sql = "insert into user (id,name) values (?,?)"; ciXAyT cG
PreparedStatement ps = cn.prepareStatement(sql); 9:esj{X
ps.setInt(1,xxx); .rMGI"
ps.setString(2,xxx); eH6#'M4+\
... vu*08<M~i|
ResultSet rs = ps.executeQuery(); // 查询 K3@UoR
int c = ps.executeUpdate(); // 更新 q=
tDMK'h
=6%0pu]0
3、处理执行结果 .vb*|So
查询语句,返回记录集ResultSet *=ALns?y
更新语句,返回数字,表示该更新影响的记录数 UV:_5"-
ResultSet的方法 MqNp*n2
1、next(),将游标往后移动一行,如果成功返回true;否则返回false N8!B2uPQ
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 6ZF5f^M^
#2`tsZ]=I
4、释放连接 y6Rg@L&U
cn.close(); S3n$
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection a{{([uZ
}5%!:=
可滚动、更新的记录集 0{jRXa-(
1、创建可滚动、更新的Statement !e%#Zb
MIo
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); kdv>QZ
该Statement取得的ResultSet就是可滚动的 UyvFR@
2、创建PreparedStatement时指定参数 <7)@Jds\
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); /FQumqbnt
ResultSet.absolute(9000); gsZCWT
批量更新 2B*9]AHny
1、Statement JNsK
Statement sm = cn.createStatement(); 8S)k]$ wf%
sm.addBatch(sql1); '|6j1i0x
sm.addBatch(sql2); _jr%s
... UZXnABg,J
sm.executeBatch() WJhI6lu
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 WSh+5](:
2、PreparedStatement @90)
PreparedStatement ps = cn.preparedStatement(sql); 6r^(VT
{ !,I}2,1%k
ps.setXXX(1,xxx); 5Rc
5/ m
... (h2bxfV~+
ps.addBatch(); _o<8R@1
} S=o Ab&
ps.executeBatch(); SB]|y-su
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 IV!&jL
Xd{"+'29
事务的处理 sg2T)^*V
1、关闭Connection的自动提交 8Kv=Zp,?`
cn.setAutoCommit(false); yfi.<G)S
2、执行一系列sql语句 c7sW:Yzil
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close M$|^?U>cm
Statement sm ; F2lTDuk>C
sm = cn.createStatement(insert into user...); e6,/i
sm.executeUpdate(); z$S)|6Q
sm.close(); c"6<p5j!
sm = cn.createStatement("insert into corp...); :+en8^r%
sm.executeUpdate(); `@-H
;
sm.close(); L`3 g5)V
3、提交 Pij*?qmeQ
cn.commit(); LzP+l>m
4、如果发生异常,那么回滚 0o c5ahp
cn.rollback();