java 数据库基本操作 ;6aTt2BQ
1、java数据库操作基本流程 ]>h2h ?2te
2、几个常用的重要技巧: ;c73:'e
可滚动、更新的记录集 2GRh8G&5
批量更新 EgIFi{q=0
事务处理 xQs2)
2%g)0[1
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 }vBk,ED
1、取得数据库连接 .Ajs0 T2
1)用DriverManager取数据库连接 ^T\JFzV
例子 Ikiv+Fq(
String className,url,uid,pwd; k>#,1GbNZy
className = "oracle.jdbc.driver.OracleDriver"; ,lm.~% }P*
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; e#`wshtN:
uid = "system"; T1m097
pwd = "manager"; !Dp4uE:Pq
Class.forName(className); YIs (Q
Connection cn = DriverManager.getConnection(url,uid,pwd); Qg
2)用jndi(java的命名和目录服务)方式 btb-MSkO
例子 k^gnOU ;
String jndi = "jdbc/db"; NC::;e
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); D6Ov]E:fa
DataSource ds = (DataSource) ctx.lookup(jndi); r-]Au -
Connection cn = ds.getConnection(); UNLy{0tA
多用于jsp中 2GECcx53
2、执行sql语句 c0ET]
1)用Statement来执行sql语句 *ie#9jA
String sql; m;o \.s
Statement sm = cn.createStatement(); $oK,&_
sm.executeQuery(sql); // 执行数据查询语句(select) .(Q3M0.D
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); ^!H8"CdC3
2)用PreparedStatement来执行sql语句 pLMki=.Ld
String sql; '/
3..3k
sql = "insert into user (id,name) values (?,?)"; NwM =
PreparedStatement ps = cn.prepareStatement(sql); -WP_0
ps.setInt(1,xxx); UMUr"-l =
ps.setString(2,xxx); *EOIgQp
... h
&9Ld:p
ResultSet rs = ps.executeQuery(); // 查询 B]]_rl,
int c = ps.executeUpdate(); // 更新 y6Xfddd61
M9*7r\hqYV
3、处理执行结果 <x DD*u
查询语句,返回记录集ResultSet ^.jIus5
更新语句,返回数字,表示该更新影响的记录数 PIP2(-{ai
ResultSet的方法 SiHZco
I
1、next(),将游标往后移动一行,如果成功返回true;否则返回false k<ds7k1m
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 R^P~iAO
[0N==Ym1
4、释放连接 dix\hqZ
cn.close(); 3EB8ls2
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection 1R9hA7y&,/
LoUi Yf
可滚动、更新的记录集 C)`ZI8
1、创建可滚动、更新的Statement ~d_Z?Z
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); s&Y~48{
该Statement取得的ResultSet就是可滚动的 ;hNnF&l
2、创建PreparedStatement时指定参数 k7)H%31;
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); R{)Sv| +`
ResultSet.absolute(9000); YcE:KRy
批量更新 X4*{CM
1、Statement mzTF2K
Statement sm = cn.createStatement(); [>&Nhn0iY
sm.addBatch(sql1); '#[U7(lIQ
sm.addBatch(sql2); A:[La#h|p
... DIodQkF
sm.executeBatch() iOm1U_S
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 ga^O]yK
2、PreparedStatement 0iqa]Am
PreparedStatement ps = cn.preparedStatement(sql); Lhu2;F\/
{ %).phn"ij[
ps.setXXX(1,xxx); "?lirOD
... yi%A*q~MT
ps.addBatch(); #B:J7&@fn
} K^?yD
ps.executeBatch(); VcIsAK".4[
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 T=:&W3
g"]%5Ow1
事务的处理 -QCo]:cp
1、关闭Connection的自动提交 g*\u8fpRq
cn.setAutoCommit(false); ymXR#E
2、执行一系列sql语句 h>$,97EU
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close >[,Rt"[V
Statement sm ; hFuS>Hx
sm = cn.createStatement(insert into user...); j(6:
sm.executeUpdate(); P
(jlWr$$
sm.close(); UZMo(rG.]{
sm = cn.createStatement("insert into corp...); d6,%P6
sm.executeUpdate(); o\h[K<^>)
sm.close(); WaF<qhu*
3、提交 -vwkvNn8
cn.commit(); "cRc~4%K
4、如果发生异常,那么回滚 u].=b$wHHM
cn.rollback();