java 数据库基本操作 ]0D}T'wM
1、java数据库操作基本流程 T+LJ*I4
2、几个常用的重要技巧: 9*6]&:fm
可滚动、更新的记录集 GFSt<k)
批量更新 VC5_v62&.
事务处理 bg|!'1bD`5
L.6WiVP)
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 =Cqv=
1、取得数据库连接 PR<||"03
1)用DriverManager取数据库连接 zr76_~B1u
例子 n{*e 9Aw
String className,url,uid,pwd; wo5ZxM
className = "oracle.jdbc.driver.OracleDriver"; Uadr>#C*
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; A5#y?Aq
uid = "system"; &PcyKpyd
pwd = "manager"; }4co)B"
Class.forName(className); `h;k2Se5
Connection cn = DriverManager.getConnection(url,uid,pwd); 8GJdRL(
2)用jndi(java的命名和目录服务)方式 '+<(;2Z
vL
例子 Z: 2I/
String jndi = "jdbc/db"; Y^$HrI(vq
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); e2CV6F@a
DataSource ds = (DataSource) ctx.lookup(jndi); m9M
FwfZ
Connection cn = ds.getConnection(); ^SEdA=!
多用于jsp中 E04l|
2、执行sql语句 hwnx<f '
1)用Statement来执行sql语句 jW*1E*"
String sql; ^[TV;9I*
Statement sm = cn.createStatement(); [n,?WwC
sm.executeQuery(sql); // 执行数据查询语句(select) 2k7bK6=nm
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); zH)_vW
2)用PreparedStatement来执行sql语句 B~r}c4R{7
String sql; B%<e FFV\
sql = "insert into user (id,name) values (?,?)"; #i QX6WF
PreparedStatement ps = cn.prepareStatement(sql); S_J :&9L
ps.setInt(1,xxx); `ia %)@
ps.setString(2,xxx); )tZ`K
|
... %@&a7JOL
ResultSet rs = ps.executeQuery(); // 查询 #*q2d
int c = ps.executeUpdate(); // 更新 bggusK<
!J>A,D"-
3、处理执行结果 exR^/|BR
查询语句,返回记录集ResultSet g=]&A
更新语句,返回数字,表示该更新影响的记录数 WbjF]b\
ResultSet的方法 _|c&@M
1、next(),将游标往后移动一行,如果成功返回true;否则返回false cErI%v}v0
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 #,f{Ok+
t\U$8l_;
4、释放连接 -@%%*YI>
cn.close(); <SXZx9A!
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection jThbeY[
dK?);*w]
可滚动、更新的记录集 ~P1_BD(
1、创建可滚动、更新的Statement H9"= p
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); ~2%3FV^
该Statement取得的ResultSet就是可滚动的 HR{s&ho
2、创建PreparedStatement时指定参数 ^^LjI
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); %&] 1FhL
ResultSet.absolute(9000); vgPUIxB@
批量更新 y]qsyR18i
1、Statement tbj=~xYf
Statement sm = cn.createStatement(); 4_Rdp`x#J
sm.addBatch(sql1); 6TFo|z!C
sm.addBatch(sql2); v+q<BYq
... aPIr_7e
sm.executeBatch() X B I;Lg
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 n
E:'Zxj
2、PreparedStatement \XH@b6{
PreparedStatement ps = cn.preparedStatement(sql); r%MyR8'k]
{ -ut=8(6&
ps.setXXX(1,xxx); 0<P(M: a
... Lo3-X
ps.addBatch(); OhWC}s
} XL"=vbD
ps.executeBatch(); 3ut_Bt\
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 }brr ))
c cr" ep
事务的处理 z-Hkz
1、关闭Connection的自动提交 cIZc:
cn.setAutoCommit(false); QWhp:]}
2、执行一系列sql语句 HYIRcY
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close &-F"+v,+
Statement sm ; q6)N*?
sm = cn.createStatement(insert into user...); MSB%{7'o
sm.executeUpdate(); Uz>Yn&{y6
sm.close(); nZW4} ~0j
sm = cn.createStatement("insert into corp...); Y@:3 B:m#
sm.executeUpdate(); j;0ih_Z@4W
sm.close(); Qv !rUiXq
3、提交 jeFN*r_
cn.commit(); h#R&=t1,^
4、如果发生异常,那么回滚 [f(uqLdeM
cn.rollback();