java 数据库基本操作 K_}K@'
1、java数据库操作基本流程 P?P#RhvA1
2、几个常用的重要技巧: XC#oB~K'
可滚动、更新的记录集 aV0"~5
批量更新 ]\HvK CN}
事务处理 /&JT~M
s_p!43\J
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 +k R4E23:
1、取得数据库连接 [AJJSd/:
1)用DriverManager取数据库连接 nQ3A~ ()
例子 Bdpy:'fJn
String className,url,uid,pwd; l,aay-E
className = "oracle.jdbc.driver.OracleDriver"; V0 a3<6@4
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; w7&A0M
uid = "system"; '8kP.l
pwd = "manager"; ~6md !o%i
Class.forName(className); )NT*bLRPQ
Connection cn = DriverManager.getConnection(url,uid,pwd); (A.C]hD
2)用jndi(java的命名和目录服务)方式 h'nY3GrU
例子 EU Fa5C:
String jndi = "jdbc/db"; ]A_`0"m.U
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); j3ls3H&
DataSource ds = (DataSource) ctx.lookup(jndi); 0jWVp-y
Connection cn = ds.getConnection(); 4E}Yt$|
多用于jsp中 -m#)B~)
2、执行sql语句 HTTCTR
1)用Statement来执行sql语句 lPAQ3t!,
String sql; SSzIih@u
Statement sm = cn.createStatement(); :\_ 5oVb
sm.executeQuery(sql); // 执行数据查询语句(select) Qn2&nD%zi
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); buHJB*?9
2)用PreparedStatement来执行sql语句 $3kH~3{]
String sql; 7F~X,Dk_
sql = "insert into user (id,name) values (?,?)"; 9}
.z;prz
PreparedStatement ps = cn.prepareStatement(sql); es0hm2HT3
ps.setInt(1,xxx); sV*H`N')S
ps.setString(2,xxx); wVtwx0|1
... )0k53-h&
ResultSet rs = ps.executeQuery(); // 查询 }c:M^Ff
int c = ps.executeUpdate(); // 更新 3Tm+g2w2V8
d2L&Z_}
3、处理执行结果 I)HPO,7
查询语句,返回记录集ResultSet 3=V&K-
更新语句,返回数字,表示该更新影响的记录数 'dc#F3
ResultSet的方法 1Ai^cf:S
1、next(),将游标往后移动一行,如果成功返回true;否则返回false e]$s
t?
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 o^wqFX(Y
X2"/%!65{
4、释放连接 >/6 _ ^
cn.close(); {id4:^u&;
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection u)Whr@m
8H`[*|{'
可滚动、更新的记录集 GTxk%
1、创建可滚动、更新的Statement MiX 43Pk]
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); 4Wp=y
该Statement取得的ResultSet就是可滚动的 ;mi%F3
2、创建PreparedStatement时指定参数 bcz:q/f}@
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); 9:lFo=
ResultSet.absolute(9000); oxtay7fx
批量更新 F((4U"
1、Statement _)iCa3z
Statement sm = cn.createStatement(); /BL4<T f
sm.addBatch(sql1); tX~w{|k
sm.addBatch(sql2); cm+P]8o%{
... dDGQ`+H9
sm.executeBatch() 1=v*O.XW`
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 =-Ck4e *T
2、PreparedStatement 62NsJ<#>
PreparedStatement ps = cn.preparedStatement(sql); b#o|6HkW
{ ]/{)bpu
ps.setXXX(1,xxx); :rP=t ,
... Zj
Z^_X3
ps.addBatch(); iU:cW=W|M\
} >8[Z.fX
ps.executeBatch(); z'7]h TA
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 y>ktcuML
eszG0Wu
事务的处理 43 :X,\~)
1、关闭Connection的自动提交 ^=*;X;7
cn.setAutoCommit(false); ]I6 J7A[
2、执行一系列sql语句 0tJZ4(0
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close A":T1s
Statement sm ; @PIp*[7oC
sm = cn.createStatement(insert into user...); 8xMX
sm.executeUpdate(); c+GG\:gM
sm.close(); 6wg^FD_Q
sm = cn.createStatement("insert into corp...); -I%5$`z
sm.executeUpdate(); rSNi@;
sm.close(); c[s4EUG
3、提交 (w zQ2Dk
cn.commit(); {\\Tgs
4、如果发生异常,那么回滚 U%/+B]6jP
cn.rollback();