java 数据库基本操作 /!MKijI
1、java数据库操作基本流程 & 0WQF
2、几个常用的重要技巧: V'MY+#
可滚动、更新的记录集 yBIX<P)vE'
批量更新 yTZo4c"
事务处理 cF8 X
}^p<Y5{b
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 oM
Z94,3
1、取得数据库连接 |\G^:V[.
1)用DriverManager取数据库连接 ACZK]~Y'N*
例子 VY+P c/b
String className,url,uid,pwd; yO!M$aOn/
className = "oracle.jdbc.driver.OracleDriver"; J|%bRLX@>
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; '\xE56v)F
uid = "system"; Ot:}Ncq^\O
pwd = "manager";
/7:+.#Ag`
Class.forName(className); fmc\Li
Connection cn = DriverManager.getConnection(url,uid,pwd); 5s`r&2 w
2)用jndi(java的命名和目录服务)方式 )7o?}"I
例子 p:W]
String jndi = "jdbc/db"; .jk
A'i@
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); ;e/F( J
DataSource ds = (DataSource) ctx.lookup(jndi); &);P|v`8
Connection cn = ds.getConnection(); kV4Oq.E
多用于jsp中 [A"=!e$<
2、执行sql语句 GdVF;
1)用Statement来执行sql语句 jY]51B
String sql; `8RKpZv&
Statement sm = cn.createStatement(); U,;796h
sm.executeQuery(sql); // 执行数据查询语句(select) 4nh=Dq[
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); zp<B,Ls
2)用PreparedStatement来执行sql语句 vlE]RB
String sql; 7}6CUo
sql = "insert into user (id,name) values (?,?)"; gkA_<,38
PreparedStatement ps = cn.prepareStatement(sql); +{V`{'
ps.setInt(1,xxx); v~x4Y,m%
ps.setString(2,xxx); g<.Is
V
... ci$J?a
ResultSet rs = ps.executeQuery(); // 查询 Ef28
int c = ps.executeUpdate(); // 更新 ~&Ne
P
xz.Jmv
3、处理执行结果 m|c[C\)By
查询语句,返回记录集ResultSet #vga
qe9
更新语句,返回数字,表示该更新影响的记录数 :Q]"dbY^
ResultSet的方法 NlKVl~_ C
1、next(),将游标往后移动一行,如果成功返回true;否则返回false ^7YNM<_%@
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 )Se$N6u-
fi`\e
W
4、释放连接 (tg9"C
cn.close(); [YHtBM:y
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection (=Kv1
H aD
qxu3y+po]
可滚动、更新的记录集 \U>&W
1、创建可滚动、更新的Statement VwPoQ9pIS
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); T]-MrnO
该Statement取得的ResultSet就是可滚动的 [xr^t1
2、创建PreparedStatement时指定参数 L/C~l3
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); LR>s2zu-
ResultSet.absolute(9000); !U m9ceK
批量更新 vIOGDI>
1、Statement G:tY1'5
Statement sm = cn.createStatement(); vszm9Qf
sm.addBatch(sql1); OoH-E.lp
sm.addBatch(sql2); }YFM40H
... Mh5>
hD
sm.executeBatch() m}s.a.x
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 Rk3
bZvj3
2、PreparedStatement AguE)I&m
PreparedStatement ps = cn.preparedStatement(sql); F=1 #qo<?
{ yxp,)os:
ps.setXXX(1,xxx); :;]9,n
... A`Y^qXFb`
ps.addBatch(); d!0rq4v7
} TPk?MeVy%W
ps.executeBatch(); Wtcib-
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 !W@mW
5J|
B\)Te9k'
事务的处理 TaBya0-
1、关闭Connection的自动提交 DR}I+<*%aD
cn.setAutoCommit(false); `Y4K w
2、执行一系列sql语句 4Zwbu
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close ?<C(ga
Statement sm ; uMZ~[Sz
sm = cn.createStatement(insert into user...); 7)r]h?
sm.executeUpdate(); 3J
&Ros
sm.close(); dVEs^ZtI
sm = cn.createStatement("insert into corp...); VYkh@j
sm.executeUpdate(); Z,E$4Z
sm.close(); C:5-h(#
3、提交 Z}uY%]
cn.commit(); )-Hs]D:
4、如果发生异常,那么回滚 }" vxYB!h3
cn.rollback();