java 数据库基本操作 <bx9;1C>zd
1、java数据库操作基本流程 wqwJpWIe
2、几个常用的重要技巧: f~q&.,I(
可滚动、更新的记录集 KJ)nGoP>
批量更新 lQsQRp
事务处理 B![5+
'iVo,m[yKU
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 BH-[q9pf
1、取得数据库连接 0o<qEo^
1)用DriverManager取数据库连接 5i/E=D
例子 -PnC^r0L$
String className,url,uid,pwd; HEuM"2{DMM
className = "oracle.jdbc.driver.OracleDriver"; *3/7wSV:
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; Hr+-ndH!Pq
uid = "system"; VBX#
!K1Q
pwd = "manager"; r$#G%FMv
Class.forName(className); [[e |GQ
Connection cn = DriverManager.getConnection(url,uid,pwd); 3opLLf_g
2)用jndi(java的命名和目录服务)方式 b66X])+4jE
例子 pq[mM!;#v
String jndi = "jdbc/db"; w}.'Tebu
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); [Kj:~~`T
DataSource ds = (DataSource) ctx.lookup(jndi); 0v@/I<
Connection cn = ds.getConnection(); AIm$in`P
多用于jsp中 jOb[h=B"
2、执行sql语句 nP3GI:mjL
1)用Statement来执行sql语句 |w JZU
String sql; YF -w=Y6
Statement sm = cn.createStatement(); HLe^|
sm.executeQuery(sql); // 执行数据查询语句(select) $CmX
&%L=
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); vaj66nV
2)用PreparedStatement来执行sql语句 IPO[J^#Me
String sql; O8r"M8
sql = "insert into user (id,name) values (?,?)"; ^)q2\YE;
PreparedStatement ps = cn.prepareStatement(sql); (J*w./
ps.setInt(1,xxx); )zXyV]xe
ps.setString(2,xxx); Y(y9l{'
... (oXN >^-D
ResultSet rs = ps.executeQuery(); // 查询 VWshFI
int c = ps.executeUpdate(); // 更新 &{ {DS
cY2-T#rL
3、处理执行结果 N}Ks[2
查询语句,返回记录集ResultSet }iSakq'
更新语句,返回数字,表示该更新影响的记录数 |"yf@^kdC
ResultSet的方法 z9ShP&^4[
1、next(),将游标往后移动一行,如果成功返回true;否则返回false 8sIrG
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 B"PHJj
y"\,%.
4、释放连接 w"v'dU^
cn.close(); }%YHm9)
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection 4VNb`!e
grQnV' q
可滚动、更新的记录集 Q$)|/Y))
1、创建可滚动、更新的Statement $a\Uv0:xRx
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); <}
y p
该Statement取得的ResultSet就是可滚动的 +^kxFQ(:
2、创建PreparedStatement时指定参数 ,%h!% nz!
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); =YGP%}_.p{
ResultSet.absolute(9000); "F"_G
批量更新 >Mn>P!
1、Statement {1MGb%xW
Statement sm = cn.createStatement(); uXLZtfu{
sm.addBatch(sql1); bV`C;RPn
sm.addBatch(sql2); _?s %MNaX
... bw<w
u}ED
sm.executeBatch() OF&h=1De,
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 V->%)d3i
2、PreparedStatement b!]0mXU
PreparedStatement ps = cn.preparedStatement(sql); s$Zq/l$1x
{ *e<Eu>fW#&
ps.setXXX(1,xxx); fcICFReyV
... 5$oewjLO
ps.addBatch();
^ MT9n
} ChTXvkdH
ps.executeBatch(); ,iVPcza
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 ]&:b<]K3
nnE_OK!}T
事务的处理 h1XMx'}B
1、关闭Connection的自动提交 (.1 rtj
cn.setAutoCommit(false); "W@XP+POAY
2、执行一系列sql语句 3%R{"Q"
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close +%wWSZ<#
Statement sm ; lKEX"KQ!
sm = cn.createStatement(insert into user...); 0HR|aqPo
sm.executeUpdate(); ck+b/.gw`
sm.close(); qon{
g
sm = cn.createStatement("insert into corp...); tKZ&1E
sm.executeUpdate(); `\jTpDV_W
sm.close(); h.V]f S
3、提交 YN@6}B#1
cn.commit(); NLQE"\#a
4、如果发生异常,那么回滚 'e]HP-Y<
cn.rollback();