java 数据库基本操作 zSU,le
1、java数据库操作基本流程 h/5S2EB0!O
2、几个常用的重要技巧: 9 wbQ$>G9
可滚动、更新的记录集 4y?n62N8$
批量更新 ] $r].,&
事务处理 ".waCt6
&1?6Q_p6c
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 F|qMo|
1、取得数据库连接 a]xGzv5
1)用DriverManager取数据库连接 N)AlQ'Lwx
例子 u[Si=)`VPk
String className,url,uid,pwd; zy nX9t
className = "oracle.jdbc.driver.OracleDriver"; f 1+
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; lX)AbK]nb
uid = "system"; .4tu{\YX
pwd = "manager"; ,\c V,$
Class.forName(className); F:q8.^HTJ
Connection cn = DriverManager.getConnection(url,uid,pwd); W5= j&&|!
2)用jndi(java的命名和目录服务)方式 "bF52lLu
例子 D,[Nn_N
String jndi = "jdbc/db"; N3aqNRwlk
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); X0-PJ-\aD@
DataSource ds = (DataSource) ctx.lookup(jndi); l>`66~+s,`
Connection cn = ds.getConnection(); _q4O2Fx0
多用于jsp中 oz)4YBf
2、执行sql语句 i*m;kWu,
1)用Statement来执行sql语句 wet[f {c
String sql; ipg`8*My
Statement sm = cn.createStatement(); w,vnpdT
sm.executeQuery(sql); // 执行数据查询语句(select) r@qLG"[\c
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); 7pQ5`;P
2)用PreparedStatement来执行sql语句 vmrs(k "d#
String sql; -N wic|
sql = "insert into user (id,name) values (?,?)"; 1'Q6l
PreparedStatement ps = cn.prepareStatement(sql); 3S]QIZ1
ps.setInt(1,xxx); R=D}([pi
ps.setString(2,xxx); _ahp7-O
... , QWus"5H
ResultSet rs = ps.executeQuery(); // 查询 O6)Po
int c = ps.executeUpdate(); // 更新 "aCB}
zow8 Q6f
3、处理执行结果 ;-@: }/
查询语句,返回记录集ResultSet ")\V
更新语句,返回数字,表示该更新影响的记录数 e98QT9
ResultSet的方法 >yXhP6
1、next(),将游标往后移动一行,如果成功返回true;否则返回false g3&nxZ
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 '@ Y@Fs
\G>C{v;
4、释放连接 u/6if9B
cn.close(); M9BEG6E9
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection yq k8)\p
?O#,{ZZf=
可滚动、更新的记录集 0#eb] c
1、创建可滚动、更新的Statement H1B%}G*Ir-
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); cnQ2/ZZp~
该Statement取得的ResultSet就是可滚动的 [~
2m*Q
2、创建PreparedStatement时指定参数 %aMC[i
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); k?&GL!?
ResultSet.absolute(9000); R@z`
批量更新 /KF@Un_Ow
1、Statement "``>ii
Statement sm = cn.createStatement(); d4 \
sm.addBatch(sql1); UCfouQ Cj
sm.addBatch(sql2); eS@j? Y0y
... G"J
nQ
sm.executeBatch() ]bh%pn
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 oo &|(+"O_
2、PreparedStatement vr4r,[B6y
PreparedStatement ps = cn.preparedStatement(sql); [>54?4{|.
{ abUO3
Y{
ps.setXXX(1,xxx); F%o!+%&7
... (XmmbAbVom
ps.addBatch(); vVvF e~y]
} 6P717[
ps.executeBatch(); J QnaXjW2
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 p{LbTjdNc
K'J_AMBL
事务的处理 %E&oe $[B
1、关闭Connection的自动提交 ?rQ .nN
cn.setAutoCommit(false); E9j<+Ik
2、执行一系列sql语句 FsWp>}o
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close 5Ex[}y9L`
Statement sm ; Y=G`~2Pr=
sm = cn.createStatement(insert into user...); OHBCanZZ,
sm.executeUpdate(); dX)aD
$m
sm.close(); [.xY>\e
sm = cn.createStatement("insert into corp...); o
[V8h@K)
sm.executeUpdate(); K=0xR*ll5
sm.close(); TY %zw6 #p
3、提交 DoQ^caa@
cn.commit(); JZ-@za6u
4、如果发生异常,那么回滚 k6ry"W3
cn.rollback();