java 数据库基本操作 /"D,gn1S*
1、java数据库操作基本流程 b<~8\\&
2、几个常用的重要技巧: 77[TqRLf
可滚动、更新的记录集 r1-MO`6
批量更新 Xzg >/w
8J
事务处理 H i8V=+
?.<
Qgd
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 e_Hpai<b
1、取得数据库连接 L5`k3ap|
1)用DriverManager取数据库连接 PbZ%[F
例子 Bc }o3oc
String className,url,uid,pwd; V;MmPNP|
className = "oracle.jdbc.driver.OracleDriver"; CqC
)H7A
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; >YWK"~|i~
uid = "system"; :stHc,
pwd = "manager"; v LN KX;9
Class.forName(className); Ot-P
J
i
Connection cn = DriverManager.getConnection(url,uid,pwd); EIQ3vOq6
2)用jndi(java的命名和目录服务)方式 U&])ow):
例子 _";w*lg}
String jndi = "jdbc/db"; rrRv 7J&Q
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); o5&b'WUJ=
DataSource ds = (DataSource) ctx.lookup(jndi); :
pUu_
Connection cn = ds.getConnection(); .tG3g:
多用于jsp中 ,hI$nF0}p
2、执行sql语句 [q!]Ds"
_
1)用Statement来执行sql语句 Gn^lF7yE
String sql; e`={_R{N
Statement sm = cn.createStatement(); *w*K&$g
sm.executeQuery(sql); // 执行数据查询语句(select) &t8,326;
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); < r~hU*u
2)用PreparedStatement来执行sql语句 CUH u=
String sql; q:)PfP+
sql = "insert into user (id,name) values (?,?)"; KZ[TW,Gw
PreparedStatement ps = cn.prepareStatement(sql); |s/N?/qi
ps.setInt(1,xxx); ZKEoU!
ps.setString(2,xxx); 2! ,ndLA
... H ;=^
W
ResultSet rs = ps.executeQuery(); // 查询 #6|ve?`I
int c = ps.executeUpdate(); // 更新 E3j`e>Yz
?sdSi--
3、处理执行结果 %!A:Ka!m.
查询语句,返回记录集ResultSet t27UlFX
更新语句,返回数字,表示该更新影响的记录数 ck0%H#BYY
ResultSet的方法 D1-/#QN$1
1、next(),将游标往后移动一行,如果成功返回true;否则返回false cKkH*0B5
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 ~L<"]V+B
d'MZ%.#
4、释放连接 | 8mWR=9fs
cn.close(); Q?1.GuF
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection +8Q @R)3
CtN\-E-
可滚动、更新的记录集 *cWHl@4
1、创建可滚动、更新的Statement 7Ji'7$
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); )C?H m^#
该Statement取得的ResultSet就是可滚动的 a+lNXlh=
2、创建PreparedStatement时指定参数 %$zak@3%'
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); ;5X~"#%U_
ResultSet.absolute(9000); AFL'Ox]0
批量更新 \jk*Nm8;
1、Statement l2n`fZL
Statement sm = cn.createStatement(); vS~tr sI
sm.addBatch(sql1); t^MTR6y+8
sm.addBatch(sql2); AcnY6:3Y|
... YFu,<8"swe
sm.executeBatch() Rq+7&%dy
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 BV@q@C
2、PreparedStatement W*S4gPGM
PreparedStatement ps = cn.preparedStatement(sql);
5TpvJ1G
{ ,^e2ma|z
ps.setXXX(1,xxx); b(|&e
... HN`qMGW^
ps.addBatch(); Co nik`
} ?m~1b_@A{
ps.executeBatch(); 9>-6Y
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。
YMv}]
g$e|y#Ic$
事务的处理 Cx~;oWZ
1、关闭Connection的自动提交 9a=:e=q3#
cn.setAutoCommit(false); 7W SP0Xyz
2、执行一系列sql语句
D~"a"
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close xF3FY0U[
Statement sm ; L"9Z{o7
sm = cn.createStatement(insert into user...); 8vq-|p
sm.executeUpdate(); ef7 U7
sm.close(); "aKlvK:77
sm = cn.createStatement("insert into corp...); >CrrxiG
sm.executeUpdate(); >%`SXB&9
sm.close(); N}nE9z5
3、提交 +p>h` fc
cn.commit(); BhAT@%
4、如果发生异常,那么回滚 2 ^"j]g>mj
cn.rollback();