java 数据库基本操作 -wrVhCd~g]
1、java数据库操作基本流程 kYnp$8
2、几个常用的重要技巧: _fE$KaP
可滚动、更新的记录集 uwo\FI
批量更新 Ic')L*i7O
事务处理 8c^Hfjr0
9U]j@*QN
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 ;?.w!|6
1、取得数据库连接 Zj5B}[,l\
1)用DriverManager取数据库连接 c4Wl^E8
例子
GW\66$|
String className,url,uid,pwd; O
=0j I
className = "oracle.jdbc.driver.OracleDriver"; "'v^X!"
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; Ze"m;T
uid = "system"; 28x:]5=jb
pwd = "manager"; @M&qH[tK-A
Class.forName(className); 2 pmqP-pKd
Connection cn = DriverManager.getConnection(url,uid,pwd); 4c9a"v
2)用jndi(java的命名和目录服务)方式 7-A/2/G<
例子 0I['UL^!F
String jndi = "jdbc/db"; =>htX(k}
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); 9>T5~C'*
DataSource ds = (DataSource) ctx.lookup(jndi); .)Zs:50l
Connection cn = ds.getConnection(); EaKbG>
多用于jsp中 FL E3LH
2、执行sql语句 l?)!^}Qc
1)用Statement来执行sql语句 @RXkj-,eC#
String sql; b!oj3|9
Statement sm = cn.createStatement(); Ge1b_?L_
sm.executeQuery(sql); // 执行数据查询语句(select) EFn[[<&><t
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); bZW dd6
2)用PreparedStatement来执行sql语句 |qz&d=>
String sql; {@ Z=b5/P
sql = "insert into user (id,name) values (?,?)"; J>8kJCh9g
PreparedStatement ps = cn.prepareStatement(sql); 8e32NJ^k~
ps.setInt(1,xxx); mnL+@mm
ps.setString(2,xxx); s`gfz}/
... bYBE h n
ResultSet rs = ps.executeQuery(); // 查询 $Ts;o
int c = ps.executeUpdate(); // 更新 i|[**P
6_g:2=6S
3、处理执行结果 X.+|o@G
查询语句,返回记录集ResultSet 5
BLAa1
更新语句,返回数字,表示该更新影响的记录数 \>[k0<
ResultSet的方法 b} FhC"'i
1、next(),将游标往后移动一行,如果成功返回true;否则返回false %ty`Oa2
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 M@+Pq/f:
mI'&!@WG
4、释放连接 .t7ME{
cn.close(); s
w{e |
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection o[)*Y`xq<w
qs!A)H#
可滚动、更新的记录集 i2+_~$f
1、创建可滚动、更新的Statement -G(#,rXk
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); ]-;MY@
该Statement取得的ResultSet就是可滚动的 spT$}F2n
2、创建PreparedStatement时指定参数 x;{Hd;<YF
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); K5!OvqzG
ResultSet.absolute(9000); dngG=
批量更新 M $f6.j
1、Statement !<>*|a
Statement sm = cn.createStatement(); eZ BC@y
sm.addBatch(sql1); \,ne7G21j
sm.addBatch(sql2); Ot`znJU@
... jN-!1O._G
sm.executeBatch() AQwai>eL
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 |k^C-
2、PreparedStatement 055C1RV%
PreparedStatement ps = cn.preparedStatement(sql); $plqk^P
{ >t{-_4Yv?
ps.setXXX(1,xxx); JOH\K0=e
... X0Wx\xDg[
ps.addBatch(); +ZOKfX
} =Cd{bj.8
ps.executeBatch(); SY.ZEJcv
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 <nTZs`$LwL
zx5#eMD
事务的处理 -Fq`#"
1、关闭Connection的自动提交 G*_qqb{B
cn.setAutoCommit(false); 09qfnQG
2、执行一系列sql语句 C1>zwU_zo
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close 05:?5M4};
Statement sm ; _F8THYg (
sm = cn.createStatement(insert into user...); OG9 '[o`8
sm.executeUpdate(); aWPf3Q
sm.close(); (D:-p:q.
sm = cn.createStatement("insert into corp...); 6j!idA!'
sm.executeUpdate(); w' E(9gV
sm.close(); w{ ;Sp?Os
3、提交 rp+]f\]h
cn.commit(); ..zX
4、如果发生异常,那么回滚 Mh{244|o[
cn.rollback();