java 数据库基本操作 J^zB5W,)
1、java数据库操作基本流程 )GOio+{H
2、几个常用的重要技巧: =+H,}
可滚动、更新的记录集 Dy{lgT 0k
批量更新 :W$-b
事务处理 f,Am;:\ |
#Vy:6O
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 HT6$|j
1、取得数据库连接 GyfKSj;
1)用DriverManager取数据库连接 O"wo&5b_
例子 !PgwFJ
String className,url,uid,pwd; hJ75(I
*j
className = "oracle.jdbc.driver.OracleDriver"; 5+t$4N+P
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; #!P>.".
uid = "system"; (/ -90u
pwd = "manager"; u R]8ZT")
Class.forName(className); Dn`
Connection cn = DriverManager.getConnection(url,uid,pwd); T>,[V:
2)用jndi(java的命名和目录服务)方式
|{MXDx
例子 V/RV,K1/
String jndi = "jdbc/db"; NMzq10M=6
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); PoLk{{l3
DataSource ds = (DataSource) ctx.lookup(jndi); :.(A,
Connection cn = ds.getConnection(); F6_en z
多用于jsp中 '_ys4hz}
2、执行sql语句 H`jnChD:M'
1)用Statement来执行sql语句 u[nLrEnD
String sql; ^OK;swDW
Statement sm = cn.createStatement(); 9zm2}6r4
sm.executeQuery(sql); // 执行数据查询语句(select) QkYKm<b
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); A.(e=;0bu
2)用PreparedStatement来执行sql语句 p[}~Z|(
String sql; HE0m#
sql = "insert into user (id,name) values (?,?)"; I/u>Gt
PreparedStatement ps = cn.prepareStatement(sql); 83VFBY2q
ps.setInt(1,xxx); i/PL!'oq
ps.setString(2,xxx); r(rT.D&
... BE!l{
ResultSet rs = ps.executeQuery(); // 查询 Ql"~ z^L
int c = ps.executeUpdate(); // 更新 *a-KQw
%q6I-
3、处理执行结果 #$l:%
查询语句,返回记录集ResultSet >` u8(
更新语句,返回数字,表示该更新影响的记录数 0qW"b`9R
ResultSet的方法 )[ejb?{d
1、next(),将游标往后移动一行,如果成功返回true;否则返回false 8[#EC 3
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 U[z2{\
V;hO1xfR3&
4、释放连接 Uy@:-NC)kn
cn.close(); WT}xCni
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection un}!&*+
_>_"cKS
可滚动、更新的记录集 6NQ`IC
1、创建可滚动、更新的Statement @h(Z;
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); bk]g}s
该Statement取得的ResultSet就是可滚动的 f/"IC;<~t>
2、创建PreparedStatement时指定参数 FytGg[#]
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); 2 ]n4)vv,
ResultSet.absolute(9000); WA.c.{w\
批量更新 t
;fJ`.
1、Statement ULO_?4}B
Statement sm = cn.createStatement(); 5Ha(i [d
sm.addBatch(sql1); V7D<'!
sm.addBatch(sql2); *;Za))
... m ;wj|@cF
sm.executeBatch() %CqG/ol
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 _|#P~Ft
2、PreparedStatement x@D>JG
PreparedStatement ps = cn.preparedStatement(sql); "BIhd*K[~
{ ]`|;ZQiD
ps.setXXX(1,xxx); hsJGly5H
... )~IOsTjI
ps.addBatch(); \Qq YH^M
} X]dN1/_
ps.executeBatch(); ""IPaNHQ
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 w=^~M[%w
)(pgJLW
事务的处理 )k]{FM
1、关闭Connection的自动提交 ]ZH6
.@|
cn.setAutoCommit(false); =L`PP>"rW
2、执行一系列sql语句 5UX- Qqr
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close Tq?f5swsI
Statement sm ; z>b^Ui0
sm = cn.createStatement(insert into user...); # wyjb:Ql
sm.executeUpdate(); [}4\CWM
sm.close(); IsjN
xBM
sm = cn.createStatement("insert into corp...); rl-#Ez
sm.executeUpdate(); cfy9wD
sm.close(); ]hRs -x
3、提交 (%G>TV
cn.commit(); _qH]OSo
4、如果发生异常,那么回滚 @c}Gw;e
cn.rollback();