java 数据库基本操作 {KgA
V
1、java数据库操作基本流程 ^}+\ 52w
2、几个常用的重要技巧: >._d2.Q'
可滚动、更新的记录集 G(t:s5:
批量更新 6qT@M0)i
事务处理 SES.&e|!6
?4':~;~
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 !JA;0[;l=
1、取得数据库连接 Cu7{>"
1)用DriverManager取数据库连接 ! AwMD
例子 = Pv_,%
String className,url,uid,pwd; ~
*&\5rPb
className = "oracle.jdbc.driver.OracleDriver";
7IxeSxXH
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; s#Dj>Fej
uid = "system"; {<yapBMw
pwd = "manager"; ZR!8hw8
Class.forName(className); `=Ip>7T&
Connection cn = DriverManager.getConnection(url,uid,pwd); ^Wld6:L{I
2)用jndi(java的命名和目录服务)方式 tLu&3<%
例子 E7$&:xqx
String jndi = "jdbc/db"; m|q,ixg
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); (~DW_+?]'
DataSource ds = (DataSource) ctx.lookup(jndi); 9w-\K]
Connection cn = ds.getConnection(); *X.1b!
多用于jsp中 =e6pv#
2、执行sql语句 -$8ew+
1)用Statement来执行sql语句 [oh06_rB
String sql; zA5nr`
Statement sm = cn.createStatement(); e \Qys<2r
sm.executeQuery(sql); // 执行数据查询语句(select) 9[qOfIny
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); |O(>{GH
2)用PreparedStatement来执行sql语句 t9`{^<LH
String sql; /1EAj
sql = "insert into user (id,name) values (?,?)"; qA[lL(
PreparedStatement ps = cn.prepareStatement(sql); gBqDx|G
ps.setInt(1,xxx); ?L }>9$"
ps.setString(2,xxx); rDFrreQP
... ( eKgc
ResultSet rs = ps.executeQuery(); // 查询 aMI;;iL^
int c = ps.executeUpdate(); // 更新 +RJ{)Nec
AQZ<,TE0,
3、处理执行结果 S#]]h/
查询语句,返回记录集ResultSet Xz4q^XJ
更新语句,返回数字,表示该更新影响的记录数 8Qg{@#Wr
ResultSet的方法 4|PWR_x
1、next(),将游标往后移动一行,如果成功返回true;否则返回false jC&fnt,O
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 Ql{#dcRx
r<0E[~
4、释放连接 *duG/?>P
cn.close(); dBI-y6R
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection Y|R=^
=d\
_9>,9aL
可滚动、更新的记录集 m%L!eR
1、创建可滚动、更新的Statement /MtmO$.
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); [~N;d9H+*1
该Statement取得的ResultSet就是可滚动的 =RWTjTZ
2、创建PreparedStatement时指定参数 W^iK9|[qp
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); &%fcGNzJQ
ResultSet.absolute(9000); V,KIi_Z
批量更新 <%^/uS
1、Statement QYbB\Y
Statement sm = cn.createStatement(); H?"M&mF
sm.addBatch(sql1); Ovt]3`U9J
sm.addBatch(sql2); qe.QF."y
... cH&)Iz`f
sm.executeBatch() -H%v6E%yh
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 a{ST4d'T
2、PreparedStatement (}b~}X9
PreparedStatement ps = cn.preparedStatement(sql); g!^N#o
{ ~IZ-:?+S^
ps.setXXX(1,xxx); I<2`wL=
... ?J2{6,}O*.
ps.addBatch(); Xy(QK2|
} c=u+X`
Q
ps.executeBatch(); !l*A3qA
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 <.)=CK
c';~bYZ
事务的处理 Fu.aV876\f
1、关闭Connection的自动提交 &6\&McmkX
cn.setAutoCommit(false); yu6~:$%H
2、执行一系列sql语句 9(]_so24,
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close cB,^?djJ3
Statement sm ; *fm?"0M5
sm = cn.createStatement(insert into user...);
Fbo"Csn_
sm.executeUpdate(); 437Wy+Q|e
sm.close(); + nR("Il
sm = cn.createStatement("insert into corp...); eP2Q2C8g
sm.executeUpdate(); dSwfea_
sm.close(); _YX% M|#
3、提交 04U|Frc
cn.commit(); }tt%J[
4、如果发生异常,那么回滚 Z0&^(Fb
cn.rollback();