java 数据库基本操作 hob$eWgr
1、java数据库操作基本流程 ItPK
2、几个常用的重要技巧: PWu2;JF
可滚动、更新的记录集 ZG<!^tj
批量更新 p d3&AsU
事务处理 Vb9N~v
RAI&;"
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 :Qo
1、取得数据库连接 3rg^R"&
1)用DriverManager取数据库连接 ji
-1yX
例子 J6ShIPc
String className,url,uid,pwd; 5qSZ>DZ
className = "oracle.jdbc.driver.OracleDriver"; 9nS!
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; <SZO-
-+lB
uid = "system"; XSjelA?
pwd = "manager"; CZRo{2!?U
Class.forName(className); \Egc5{
Connection cn = DriverManager.getConnection(url,uid,pwd); f {Z%:H
2)用jndi(java的命名和目录服务)方式 ja- ~`
例子 i%4k5[f.:
String jndi = "jdbc/db"; -z$2pXT ^
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); ?(8%SPRk
DataSource ds = (DataSource) ctx.lookup(jndi); y?#J`o-
O
Connection cn = ds.getConnection(); B!ibE<7,
多用于jsp中 (x0*(*A}
2、执行sql语句 lkg*AAR?'
1)用Statement来执行sql语句 ~"2@A
F
String sql; ~!9Px j*
Statement sm = cn.createStatement();
r;X0B
sm.executeQuery(sql); // 执行数据查询语句(select) p3FnYz-V
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); vcO`j<`
2)用PreparedStatement来执行sql语句 1DtMY|wP
String sql; T}Vpy`
sql = "insert into user (id,name) values (?,?)"; }k0-?_Z=1
PreparedStatement ps = cn.prepareStatement(sql); ?}v% JUcs
ps.setInt(1,xxx); >TnQ4^;v.
ps.setString(2,xxx); |;m`874
... 0DVZRB
ResultSet rs = ps.executeQuery(); // 查询 l)*,18n
int c = ps.executeUpdate(); // 更新 cievC,3*
Wd56B+
3、处理执行结果 1 3`0d
查询语句,返回记录集ResultSet yUmsE-W
更新语句,返回数字,表示该更新影响的记录数 ]~S+nlyd<
ResultSet的方法 2qMsa>~
1、next(),将游标往后移动一行,如果成功返回true;否则返回false ZWRRh^
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 v#]v,C-*
0/@ X!|X
4、释放连接 Jhy
t)@7/,
cn.close(); 6.h
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection 7Ljj#!`lUp
=/JF-#n/MA
可滚动、更新的记录集 6y,P4O*q
1、创建可滚动、更新的Statement _s^:zPl
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY);
L|lmStwe
该Statement取得的ResultSet就是可滚动的 qJXsf M6
2、创建PreparedStatement时指定参数 J7wQ=!g
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); Dnm.!L8
ResultSet.absolute(9000); :@%-f:iDj
批量更新 L@n6N|[_
1、Statement F:o#
Statement sm = cn.createStatement(); I,4-
sm.addBatch(sql1); ,o@~OTja*
sm.addBatch(sql2); 27E9NO=
... ,' rL'Ys
sm.executeBatch() ?t0zsq
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 ;s\;78`0
2、PreparedStatement
-N7L#a
PreparedStatement ps = cn.preparedStatement(sql); #>m,
Cm
{ ;[KriW
ps.setXXX(1,xxx); `o8{qU,*]N
... =6Sj}/
ps.addBatch(); Wd`
QpW
} CnSX
ps.executeBatch(); Xvj=*wg\Y
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 q bZ,K@0
?(/j<,m^
事务的处理 mDF"&.(j
1、关闭Connection的自动提交 $rpTs?j*K$
cn.setAutoCommit(false); ]r6BLZ[ %
2、执行一系列sql语句 leES YSY:
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close ke9QT#~p!-
Statement sm ; Fb|e]?w
sm = cn.createStatement(insert into user...); :x""E5H
sm.executeUpdate(); x #tu
sm.close(); V(2j*2R!
sm = cn.createStatement("insert into corp...); p37zz4
sm.executeUpdate(); ,]uX:h-EM
sm.close(); MO~~=]Y'
3、提交 ..]*Ao2
cn.commit(); RJRq` T|m
4、如果发生异常,那么回滚 ?#*
cn.rollback();