java 数据库基本操作 EH*ym#Y
1、java数据库操作基本流程 =Cy>$/H64
2、几个常用的重要技巧: B5,QJ W*
可滚动、更新的记录集 3R%UPT0>
批量更新 3E!<p
事务处理 Z\=04[
yaRcBT?
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 }{wTlR.]
1、取得数据库连接 q bZ,K@0
1)用DriverManager取数据库连接 l P$r
例子 2@R8P~^W
String className,url,uid,pwd; ^/C$L8#
className = "oracle.jdbc.driver.OracleDriver"; ;j>Vt?:Pw
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; De
nt?
uid = "system"; V(2j*2R!
pwd = "manager"; {nQ)4.e6
Class.forName(className); ~i }+P71
Connection cn = DriverManager.getConnection(url,uid,pwd); v-;XyVx
2)用jndi(java的命名和目录服务)方式 Uc&6=5~Ys\
例子 d]7|v
r]
String jndi = "jdbc/db"; Dpdn%8+Z
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); h-La'}>?
DataSource ds = (DataSource) ctx.lookup(jndi); xdL/0 N3
Connection cn = ds.getConnection(); vdH+>l
多用于jsp中 lbB.*oQ
2、执行sql语句 t8AkdSU0
1)用Statement来执行sql语句 &8]#RQy{f
String sql; 5"kx}f2$
Statement sm = cn.createStatement(); V/3 {^Fcr
sm.executeQuery(sql); // 执行数据查询语句(select) WXLe,7y
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); ;v,9v;T
2)用PreparedStatement来执行sql语句 QOT)x4!)
String sql; !_U37Uj<m
sql = "insert into user (id,name) values (?,?)";
:vYtMp
PreparedStatement ps = cn.prepareStatement(sql); Dh&:-
ps.setInt(1,xxx); dU ,)TKQ
ps.setString(2,xxx); Bn~\HW\Lh
... E[jXUOu-
ResultSet rs = ps.executeQuery(); // 查询 :F7k{~
int c = ps.executeUpdate(); // 更新 1m>^{u
+z:CZ(fb
3、处理执行结果 8"km_[JE e
查询语句,返回记录集ResultSet 9Qzjqq:"Li
更新语句,返回数字,表示该更新影响的记录数 6_R\l@a
ResultSet的方法 cxXbo a
1、next(),将游标往后移动一行,如果成功返回true;否则返回false r"{Is?yKe
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 ~LawF_]6
RDs,sj/Y9?
4、释放连接 _m9~*
cn.close(); G;(onJz
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection JsmbW|t^
6R;)
可滚动、更新的记录集 M`0(!Q}
1、创建可滚动、更新的Statement N@Xg5huO
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); ug^om{e-
该Statement取得的ResultSet就是可滚动的 l60ikc4$I
2、创建PreparedStatement时指定参数 7$(_j<o`
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); r0F_;
ResultSet.absolute(9000); V~OUE]]Q
批量更新 6xQ"bFm
1、Statement O6yP
qG *j
Statement sm = cn.createStatement(); $brKl8P
sm.addBatch(sql1); EfKM*;A
sm.addBatch(sql2); }*iAE>;
... :3*`IB !
sm.executeBatch() z*6$&sS\>
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 9c#lLKrzG
2、PreparedStatement r2RBrZ@1
PreparedStatement ps = cn.preparedStatement(sql); I+0c8T(:
{ QT#b>xV)1
ps.setXXX(1,xxx); z>6.[Z(T
... kr^0% A
ps.addBatch(); ~6p5H}'H1
} xb%/sz(4
ps.executeBatch(); ,#
]+HS^B
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 T3=(`
ytEQ`
事务的处理 S#,+Z7
1、关闭Connection的自动提交 &a.']!$^"
cn.setAutoCommit(false); qtO1hZ
2、执行一系列sql语句 eaEbH2J
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close SGt5~Txj
Statement sm ; O{~KR/
sm = cn.createStatement(insert into user...); ^D>fis
sm.executeUpdate(); sr\cVv")
sm.close(); )&>L !,z
sm = cn.createStatement("insert into corp...); NN^QUB
sm.executeUpdate(); #+$ zE#je
sm.close(); z^'n*h
3、提交 *m*`}9
cn.commit(); L${m/@9
4、如果发生异常,那么回滚 yx2z%E
cn.rollback();