java 数据库基本操作 Kpg]b"9.R
1、java数据库操作基本流程 ,2"-G";!f\
2、几个常用的重要技巧: \ZXH(N*>2t
可滚动、更新的记录集 ]2?t$"G8
批量更新 Z O&5C6qa
事务处理 =YR/|9(
9\V^q9l
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 1%H]2@
1、取得数据库连接 8!1vsEqv
1)用DriverManager取数据库连接 4jvgyi9
例子 8dP^zjPj
String className,url,uid,pwd; yKi* 8N"e<
className = "oracle.jdbc.driver.OracleDriver"; ^dQ#\uy
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; $P>ci4]t
uid = "system"; 23zB@aE_?1
pwd = "manager"; k<m{Wp;-
Class.forName(className); ~h -0rE
Connection cn = DriverManager.getConnection(url,uid,pwd); c'[l%4U8[
2)用jndi(java的命名和目录服务)方式 5MT$n4zKu
例子 p;g$D=2
String jndi = "jdbc/db"; l9\
*G;
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); t
7+ifSrz
DataSource ds = (DataSource) ctx.lookup(jndi); LG(bdj"NM
Connection cn = ds.getConnection(); <yBZsSj
多用于jsp中 PC/Oo~Gx
2、执行sql语句 _8S!w>$)
1)用Statement来执行sql语句 P/4]x@{ih
String sql; [*@"[u
Statement sm = cn.createStatement(); 4;x{@Ln
sm.executeQuery(sql); // 执行数据查询语句(select) :2}zovsdj
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); o@vo,JU
2)用PreparedStatement来执行sql语句 tv5G']vO\
String sql; 6Z0@4_Y@B6
sql = "insert into user (id,name) values (?,?)"; ml\A)8O]j/
PreparedStatement ps = cn.prepareStatement(sql); $0
eyp]XC\
ps.setInt(1,xxx); 3V2"1Ic
ps.setString(2,xxx); ^As^hY^p
... >HXT:0
ResultSet rs = ps.executeQuery(); // 查询 VD,g
int c = ps.executeUpdate(); // 更新 n)gzHch
) m[0,
3、处理执行结果 -b8Vz}Y
查询语句,返回记录集ResultSet ckS.j)@.c
更新语句,返回数字,表示该更新影响的记录数 -m3O\X
ResultSet的方法 V^[o{'+
1、next(),将游标往后移动一行,如果成功返回true;否则返回false hIE$u t +
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 9ELLJ@oNC
82{Lx7pI
4、释放连接 ,dP-sD;<
cn.close(); *Mgl X<
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection ~J)_S'
#
<`}Oi5nW
可滚动、更新的记录集 2eK!<Gj
1、创建可滚动、更新的Statement z1K@AaRx
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); f%;8]a9
该Statement取得的ResultSet就是可滚动的 `{#0C-
2、创建PreparedStatement时指定参数 8HDYA$L
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); kZfa8wL]P
ResultSet.absolute(9000); 1^jGSB.%A
批量更新 yHsmX2s
1、Statement ,3 =|a|p
Statement sm = cn.createStatement(); },lHa!<^
sm.addBatch(sql1); 8>%:MS"
sm.addBatch(sql2); :XqqhG
... W1fEUVj
sm.executeBatch() @@M
2s(
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 rOHU)2
2、PreparedStatement J'jwRn
PreparedStatement ps = cn.preparedStatement(sql); BIqZg$
{ TCWy^8LA
ps.setXXX(1,xxx); F
jsnFX;
... tJ;<=.n
ps.addBatch(); WBvh<wTw;
} yPs4S?<s
ps.executeBatch(); z|E/pm$^
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 ya.!zGH
*mwHuGbZed
事务的处理 d e)7_pCF|
1、关闭Connection的自动提交 K Rs
e
cn.setAutoCommit(false); 4>x]v!d
2、执行一系列sql语句 {}RE;5n\['
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close fyaiRn9/
Statement sm ; /%fBkA#n
sm = cn.createStatement(insert into user...); <pyLWmO
sm.executeUpdate();
~$cz`A
sm.close(); B >2" O
sm = cn.createStatement("insert into corp...); ]zK'aod
sm.executeUpdate(); $R6iG\V5
sm.close(); ++1<A&a
3、提交 vkUXMMuf+e
cn.commit(); T%zCAfx m
4、如果发生异常,那么回滚 J)tk<&X
cn.rollback();