java 数据库基本操作 ZqK]jT6V/X
1、java数据库操作基本流程 *U_oao
2、几个常用的重要技巧: E474l
可滚动、更新的记录集 ( 3;`bvYH"
批量更新 >S.91!x
事务处理 =x
H~ww (D
o^GC=Aca`
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 t)r1"oA
1、取得数据库连接 r\xXU~$9v
1)用DriverManager取数据库连接 KY+]RxX
例子 <'2u
a
String className,url,uid,pwd; [@2s&Ct;
className = "oracle.jdbc.driver.OracleDriver"; x+:zq<0|
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; Kv?;cu!
uid = "system"; @a(oB.i
pwd = "manager"; 784;]wdy\
Class.forName(className); ?D=8{!R3
Connection cn = DriverManager.getConnection(url,uid,pwd); gp/YjUH7k8
2)用jndi(java的命名和目录服务)方式 |M E{gy`5
例子 w1i?#!|
String jndi = "jdbc/db"; )eR$:uO
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); x)R0F\_
DataSource ds = (DataSource) ctx.lookup(jndi);
~6d5zI4\
Connection cn = ds.getConnection(); plXG[1;&G
多用于jsp中 .Dx2 ;lj
2、执行sql语句 }cW#045es
1)用Statement来执行sql语句 T 2|:nC)@
String sql; ML=z<u+
Statement sm = cn.createStatement(); ^:z7E1~
sm.executeQuery(sql); // 执行数据查询语句(select) v<&v]!nF
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); sykFSPy`'
2)用PreparedStatement来执行sql语句 sN]Z
#7
String sql; rPO}6lsc
sql = "insert into user (id,name) values (?,?)"; x'i0KF
PreparedStatement ps = cn.prepareStatement(sql); bl.EIyG>
ps.setInt(1,xxx); wPH+n-&e
ps.setString(2,xxx); U~/ID
... VDiOO
ResultSet rs = ps.executeQuery(); // 查询 )
,Npv3(
int c = ps.executeUpdate(); // 更新 ?Aw3lH#:
Qlh?iA
3、处理执行结果 !Uy>eji}
查询语句,返回记录集ResultSet )!,@m>0v{
更新语句,返回数字,表示该更新影响的记录数 uV77E*+7\
ResultSet的方法 +c?ie4
1、next(),将游标往后移动一行,如果成功返回true;否则返回false ^Y 7U1I
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 ,8VXA +'_
s=U\_koyH
4、释放连接 xJc.pvVPw
cn.close(); g;G5 r&T
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection 6b#~;
; )|nkI
可滚动、更新的记录集 dz,+tR~
1、创建可滚动、更新的Statement jw4TLc7p
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); OjATSmZ@@
该Statement取得的ResultSet就是可滚动的 o? \Gm
2、创建PreparedStatement时指定参数 UABbcNW
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); #(dhBEXPW;
ResultSet.absolute(9000); Q>%E`h
批量更新 o9+Q{|r
1、Statement WZK
:.y
Statement sm = cn.createStatement(); %zflx~
sm.addBatch(sql1); OG}KqG!n
sm.addBatch(sql2); ?O7iK<5N
... @_Sp3nWdu
sm.executeBatch() (9'be\
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 Yb9cW\lr
2、PreparedStatement Zs73
ad
PreparedStatement ps = cn.preparedStatement(sql); w4A#>;Qu*
{ rKIRNc#d
ps.setXXX(1,xxx); 7LdzZS0OM
... H:MUNc8i
ps.addBatch(); }4KW@L[g
} zbg+6qs})
ps.executeBatch(); 8Fx]koP.
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 mu>] 9ZW
/.@x
4cdS
事务的处理 . s-5N\
1、关闭Connection的自动提交 3):?ZCw7y
cn.setAutoCommit(false); +7Rt{C,
2、执行一系列sql语句 iAHZ0Du
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close 8]]@S"ZM,\
Statement sm ; 5Pqt_ZWy
sm = cn.createStatement(insert into user...); O!
(85rp/
sm.executeUpdate(); H &fTh
sm.close(); Da CblX
sm = cn.createStatement("insert into corp...); [yF^IlSs
sm.executeUpdate(); g]4yAV<2
sm.close(); M:(&n@e
3、提交 )f[C[Rd
cn.commit(); +C5#$5];
4、如果发生异常,那么回滚 XHNkQe
cn.rollback();