java 数据库基本操作 ],vUW#6$N
1、java数据库操作基本流程 ^mr#t #[e
2、几个常用的重要技巧: %/!n]g-
可滚动、更新的记录集 6v7H?4
批量更新 X^mvsY
事务处理 cbvK;;
WJvD,VMz
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 +!9&E{pmo
1、取得数据库连接 iR
j/Tm*T'
1)用DriverManager取数据库连接 _[}r2,e
例子 t]1j4S"pm
String className,url,uid,pwd; 6||zwwk'.
className = "oracle.jdbc.driver.OracleDriver"; #|'&%n|Z
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; i-oi?x<u&(
uid = "system"; |}zv CD
pwd = "manager"; .`4N#EjP
Class.forName(className); _%#Q
\D
Connection cn = DriverManager.getConnection(url,uid,pwd); -'&4No
2)用jndi(java的命名和目录服务)方式 Ezw(J[).C
例子 x 9}D2Ui
String jndi = "jdbc/db"; :<Z*WoEmt
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); z[:UPPbW
DataSource ds = (DataSource) ctx.lookup(jndi); ;n?72&h
Connection cn = ds.getConnection(); W70J2
多用于jsp中 #q. Q tDz
2、执行sql语句 lN94 b3_W
1)用Statement来执行sql语句 BEM_y:#
String sql; ct='Z E
Statement sm = cn.createStatement(); j3 d=O!
sm.executeQuery(sql); // 执行数据查询语句(select) (5[|h
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); fF!Mmm"
2)用PreparedStatement来执行sql语句 [OFg
(R-
String sql; ~@=:I
sql = "insert into user (id,name) values (?,?)"; 5fi6>>
PreparedStatement ps = cn.prepareStatement(sql); K|$Dnma^n
ps.setInt(1,xxx); ^)=c74;;
ps.setString(2,xxx); Pnq[r2#]:
... ?Pz:H/$
ResultSet rs = ps.executeQuery(); // 查询 l/[0N@r~
int c = ps.executeUpdate(); // 更新 %jEdgD%xV
}5dYmny
3、处理执行结果 :_v/a+\n
查询语句,返回记录集ResultSet SpbOvY=>
更新语句,返回数字,表示该更新影响的记录数 O)C
y4[
ResultSet的方法 -.ITcDg
1、next(),将游标往后移动一行,如果成功返回true;否则返回false b%>vhj&F
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 (9q61zA
cQEK>aAd
4、释放连接 NyU~8?bp
cn.close(); j~!0n[F
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection 3c] oU1GfF
.zr2!}lB
可滚动、更新的记录集 \wR bhN
1、创建可滚动、更新的Statement CU)'x
E
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); !
7,rz1s73
该Statement取得的ResultSet就是可滚动的 Th,15H
DA
2、创建PreparedStatement时指定参数 v
P8.{$
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); zp[Uh]-dMK
ResultSet.absolute(9000); `-!t 8BH
批量更新 F`,XB[}2
1、Statement 'c[4-m3bg
Statement sm = cn.createStatement(); q%8%J'Fro
sm.addBatch(sql1); TTcMIMyLT
sm.addBatch(sql2); zt{?Ntb
... ($:s}_<>s
sm.executeBatch() K~**. NF-n
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 D*3\4=6x
2、PreparedStatement H
<1g
PreparedStatement ps = cn.preparedStatement(sql); Gy0zh|me
{ 3Gi#WV4$
ps.setXXX(1,xxx); q:N"mp<%
... u
)+;(Vd
ps.addBatch(); >-rDBk
;K
} )M(; :#le
ps.executeBatch(); c;DWSgIw
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 A,-UW+:
C;2!c
事务的处理 O--
"\4
1、关闭Connection的自动提交 aWhhq@
cn.setAutoCommit(false); s6SG%Vd
2、执行一系列sql语句 e$>.x<
Eq
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close %lPAq
Statement sm ; _YzItge*
sm = cn.createStatement(insert into user...); HHu|X`tc
sm.executeUpdate(); "R@N}q<*v2
sm.close(); #W[/N|~wx
sm = cn.createStatement("insert into corp...); cE[B
(e
sm.executeUpdate(); 3~H_UGw
sm.close(); G]5m@;~l5
3、提交 88~BE ^
cn.commit(); Z4NNrA#
4、如果发生异常,那么回滚 HV'xDy[)
cn.rollback();