java 数据库基本操作 EKJc)|8
1、java数据库操作基本流程 onypwfIk)t
2、几个常用的重要技巧: YH'.Yj2
可滚动、更新的记录集 {/VL\AW5$
批量更新 T>:g
ME
事务处理 CIs1*:Q9
68G] a N3
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 Gpp}Jpj
1、取得数据库连接 sMpC4E
1)用DriverManager取数据库连接 #(wzl
例子 FO)nW:8]
String className,url,uid,pwd; |\L,r}1N
className = "oracle.jdbc.driver.OracleDriver"; P`Wf'C^h
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; dCJR,},\f
uid = "system"; s/'h LkxI
pwd = "manager"; O5n]4)<
Class.forName(className);
Tee3U%Y
Connection cn = DriverManager.getConnection(url,uid,pwd); \YF!< 2|[
2)用jndi(java的命名和目录服务)方式 KKTfxNxJn
例子 q9Opa2
String jndi = "jdbc/db"; 6!L*q
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); &=t(NI$
DataSource ds = (DataSource) ctx.lookup(jndi); ?ut juMdl
Connection cn = ds.getConnection(); !(AFT!
多用于jsp中 kFs kn55
2、执行sql语句 oUS>p" :
1)用Statement来执行sql语句 Dve5m=
String sql; cO?"
Statement sm = cn.createStatement(); 7^e}|l
sm.executeQuery(sql); // 执行数据查询语句(select) ialk6i![
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); D`@U[ `Sw
2)用PreparedStatement来执行sql语句 rnr8t]
String sql; }^bL'
sql = "insert into user (id,name) values (?,?)"; _BA_lkN+D
PreparedStatement ps = cn.prepareStatement(sql); ?mUu(D:7D
ps.setInt(1,xxx); u:kY4T+Z
ps.setString(2,xxx); D`ge3f8Wi
... 31\^9w__8
ResultSet rs = ps.executeQuery(); // 查询 Qy,qQA/
int c = ps.executeUpdate(); // 更新 %QZ!Tb
l\y*wr`
3、处理执行结果 r:Tb{cA
查询语句,返回记录集ResultSet Xr;noV-X
更新语句,返回数字,表示该更新影响的记录数 &H>dE]Hq,
ResultSet的方法 $
T_EsnN
1、next(),将游标往后移动一行,如果成功返回true;否则返回false h\ek2K
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 x5Pt\/ow
oeKc-[r
4、释放连接 >mltE$|
cn.close(); p&27|1pZm
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection zUu>kJZ
Wm&f+{LO+K
可滚动、更新的记录集
aj B
1、创建可滚动、更新的Statement U.0/r!po
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); mR@Xt#
该Statement取得的ResultSet就是可滚动的 G* 6<pp
2、创建PreparedStatement时指定参数 ~jTnjx
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); za/#R_%p
ResultSet.absolute(9000); ,99G2Ev4c
批量更新 )5OU!c
1、Statement 3?(p;
Statement sm = cn.createStatement(); >u2#<k]1&
sm.addBatch(sql1); 6p{x2>2y[
sm.addBatch(sql2); RV(z>XM
... ?R} oXSVT
sm.executeBatch() @>j \~<%
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 %%[TM(z
2、PreparedStatement l
d9#4D[#
PreparedStatement ps = cn.preparedStatement(sql); ::` wx@
{ 8[ OiG9b
ps.setXXX(1,xxx); ^w\uOd`
... .>&fwG
ps.addBatch(); [40 YoVlfM
} zl?N1>KS
ps.executeBatch(); _@TTVd
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 !:e
qPpz
{`Z)'G\`
事务的处理 6iWuBsal
1、关闭Connection的自动提交 ,&SJ?XAs
cn.setAutoCommit(false); L]}|{<3\
2、执行一系列sql语句 7:%K-LeaQu
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close OpE+e4~IF
Statement sm ; .zt]R@@6
sm = cn.createStatement(insert into user...); kv b-=
sm.executeUpdate(); Oa
.%n9ec
sm.close(); ;8Cqy80K
sm = cn.createStatement("insert into corp...); vGw}e&YI
sm.executeUpdate(); 0iHI"9z
sm.close(); '*;rm*n
3、提交
"kC>EtaX
cn.commit(); Fu/CX4R_|
4、如果发生异常,那么回滚 8<xy*=%
cn.rollback();