java 数据库基本操作 |rjHH<
1、java数据库操作基本流程 ;$`5L"I5$
2、几个常用的重要技巧: jkTh)Bm|'
可滚动、更新的记录集 P}YtT3.K
批量更新 *u?QO4>
事务处理 2#<)-Cak
kTC'`xv
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 :K:oH}4oh
1、取得数据库连接 :htz]
1)用DriverManager取数据库连接 bc+~g>o
例子 JbV\eE#KrC
String className,url,uid,pwd; (d>
M/x?W
className = "oracle.jdbc.driver.OracleDriver"; cRR[ci34k
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; {6_M$"e.
uid = "system"; nC:>1kt
pwd = "manager"; Ri<7!Y?l
Class.forName(className); fX
^hO+f
Connection cn = DriverManager.getConnection(url,uid,pwd); .Yw
2)用jndi(java的命名和目录服务)方式 }9Th`
例子 (D.B'V#>
String jndi = "jdbc/db"; :,@"I$>*/
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); _Q9 Mn-&qQ
DataSource ds = (DataSource) ctx.lookup(jndi); )bd)noZi
Connection cn = ds.getConnection(); QR ?JN\%?
多用于jsp中 nrhzNW>]
2、执行sql语句 |S0w>VH>
1)用Statement来执行sql语句 qjcPJ
String sql; @r.w+E=
Statement sm = cn.createStatement(); n7|8`?R^
sm.executeQuery(sql); // 执行数据查询语句(select) p)u?x)w=
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); Po)!vL"
2)用PreparedStatement来执行sql语句 j&(Yk"j+
String sql; I pp#{'Do
sql = "insert into user (id,name) values (?,?)"; P{bRRn4Z
PreparedStatement ps = cn.prepareStatement(sql); GiZv0>*x
ps.setInt(1,xxx); Mr0<b?I
ps.setString(2,xxx); <W>T!;4!
... 8vp*U
ResultSet rs = ps.executeQuery(); // 查询 |w{}h6a
int c = ps.executeUpdate(); // 更新 pmWt7 }
+jEtu[ ;
3、处理执行结果 9}[UZN6
查询语句,返回记录集ResultSet Q.U
wtH
更新语句,返回数字,表示该更新影响的记录数 '3p7ee&
ResultSet的方法 Jw4#u5$$Z
1、next(),将游标往后移动一行,如果成功返回true;否则返回false ^vj}
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 s~z~9#G(6
}&*wJ]j`L
4、释放连接 & t.G4
cn.close(); 5[[mS
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection ]ZMFK>"^%
RXi/&'+H
可滚动、更新的记录集 #JAy
1、创建可滚动、更新的Statement eP?=tUB!S
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); ir{li?kV
该Statement取得的ResultSet就是可滚动的 5LF &C0v
2、创建PreparedStatement时指定参数 bQvhBa?
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); D<QE?:#
ResultSet.absolute(9000); <dD)>Y.
批量更新 r6b;v2!8
1、Statement cXd?48O
Statement sm = cn.createStatement(); ee}HQ.}Ja
sm.addBatch(sql1); ? PI2X.6
sm.addBatch(sql2); }fV+Kd$CB
... fi,h`mdT?
sm.executeBatch() 8v ZY+Q >
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 9cnLf#
2、PreparedStatement NT0im%
PreparedStatement ps = cn.preparedStatement(sql); nOCCOTf
{ ^H(,^cVN
ps.setXXX(1,xxx); ^vY[d]R _\
... +%~/~1
ps.addBatch(); q:/3uC7
} ^[6S]Ft(
ps.executeBatch(); SWLt5dV
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 ${F4x "x
+F4SU(T
事务的处理 q` 0wG3
1、关闭Connection的自动提交 -cONC9=
cn.setAutoCommit(false); BN~gk~t_
2、执行一系列sql语句 S8d X8,qg
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close d7]~t|
Statement sm ; Yo*.? Mq'
sm = cn.createStatement(insert into user...); E]0}&YG
sm.executeUpdate(); 9 WO|g[Y3
sm.close(); ls@j8bVv^
sm = cn.createStatement("insert into corp...); PB(q9gf"1}
sm.executeUpdate(); BY5ODc$
sm.close(); {8pN]=SaJ~
3、提交 &cSZ?0R
cn.commit(); RYyM;<9F
4、如果发生异常,那么回滚 p.|M:C\xL
cn.rollback();