java 数据库基本操作 @&!=m]D*
1、java数据库操作基本流程 H9oXZSm
2、几个常用的重要技巧: qAS70XjOF
可滚动、更新的记录集 /k4^&
批量更新 OpWC2t)
事务处理 .E?bH V
lBizC5t!o
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 (= S"Kvb~#
1、取得数据库连接 7,) 67G;
1)用DriverManager取数据库连接 )*psDjZ7*
例子 P5yJO97
String className,url,uid,pwd; Bt|9%o06l
className = "oracle.jdbc.driver.OracleDriver"; t~+{Hr) #y
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; RT8_@8
uid = "system"; Q#yu(
pwd = "manager"; }1X11+/W
Class.forName(className); 0~PXa(!^K
Connection cn = DriverManager.getConnection(url,uid,pwd); I?^Q084
2)用jndi(java的命名和目录服务)方式 3D 4]yR5
例子 %J/fg<W1
String jndi = "jdbc/db"; "z{_hp{T^
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); ^g}gT-l%
DataSource ds = (DataSource) ctx.lookup(jndi); :,xyVb+
Connection cn = ds.getConnection(); =UI,+P:
多用于jsp中 }a #b$]Y
2、执行sql语句 \]L::"![?
1)用Statement来执行sql语句 ;PP_3`
String sql; X]3l| D
Statement sm = cn.createStatement(); Mhu53DT
sm.executeQuery(sql); // 执行数据查询语句(select) P;HVL flu
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); m<X#W W)N
2)用PreparedStatement来执行sql语句 \Y>#^b?
String sql; )V9Mcr*Ce6
sql = "insert into user (id,name) values (?,?)"; l`~a}y "n
PreparedStatement ps = cn.prepareStatement(sql); 4U LJtM3
ps.setInt(1,xxx); ?9wFV/
ps.setString(2,xxx); !4qps$p{
... fY)4]= L
ResultSet rs = ps.executeQuery(); // 查询 $DABR
int c = ps.executeUpdate(); // 更新 pQ[o3p!&9
!_^{udB}
3、处理执行结果 !9e\O5PmO
查询语句,返回记录集ResultSet '0])7jq
更新语句,返回数字,表示该更新影响的记录数 Q5`+eQ?_\
ResultSet的方法 6.`} &E
1、next(),将游标往后移动一行,如果成功返回true;否则返回false !R] CmK
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 Kdryl
lzr>WbM{{p
4、释放连接 a6#{2q
cn.close(); p ?Ij-uo"o
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection "2vNkO##
=hOj8;2
可滚动、更新的记录集 B4\:2hBq
1、创建可滚动、更新的Statement ]|((b/L3
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); [i<$ZP
该Statement取得的ResultSet就是可滚动的 8a":[Q[
2、创建PreparedStatement时指定参数 f2R+5`$
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); ;QvvU[eb
ResultSet.absolute(9000); laD.or
批量更新 F=*BvI"+
1、Statement m"?'hR2
Statement sm = cn.createStatement(); X,iuz/Q
sm.addBatch(sql1); U:pLnNp`
sm.addBatch(sql2); fRv
S@
... C,VqT6E<
sm.executeBatch() O_s9
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 b Q9"GO<X
2、PreparedStatement Us@ {w`T
PreparedStatement ps = cn.preparedStatement(sql); 6/V{>MTZg
{ bz}AO))Hk
ps.setXXX(1,xxx); 3
4A&LBwC
... l b1sV
ps.addBatch(); ZhJ|ZvJ
} a?U%l 9F
ps.executeBatch(); _I
-0,
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 >r4Y\"/j
8Jib|#!
事务的处理 XCqfAcNQ
1、关闭Connection的自动提交 =xlYQ}-(a
cn.setAutoCommit(false); gR_b~^
2、执行一系列sql语句 S8W_$=4
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close DoCQFSL
Statement sm ; dZ]\1""#H
sm = cn.createStatement(insert into user...); ^$&"<
sm.executeUpdate(); c@ZkX]g
sm.close(); 1TD&&EC
sm = cn.createStatement("insert into corp...); i-"h"nF"
sm.executeUpdate(); <=y58O]x
sm.close(); Z>MJ0J76]
3、提交
5Ky9P z
cn.commit(); e G*s1uQl
4、如果发生异常,那么回滚 EDa08+Y
cn.rollback();