java 数据库基本操作 ;M{@|z[Nv
1、java数据库操作基本流程 Y1RiuJtL
2、几个常用的重要技巧: ?EP>yCR9
可滚动、更新的记录集 BR\3ij
批量更新 L=Cm0q 3v
事务处理 A0{ !m
Cv7FVl-I
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 3LXS}~&
1、取得数据库连接 *s4h tt
1)用DriverManager取数据库连接 zK.%tx}+=k
例子 R
T/T+Q!
String className,url,uid,pwd; A[20ic
className = "oracle.jdbc.driver.OracleDriver"; ;/gH6Z?
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; !ceT>i90h
uid = "system"; 5Y<O
pwd = "manager"; ]BAM _
Class.forName(className); 8W' ,T
Connection cn = DriverManager.getConnection(url,uid,pwd); ["l1\YCi
2)用jndi(java的命名和目录服务)方式 }{"a}zOl
例子 yVA<-PlS<
String jndi = "jdbc/db"; lm'L-ZPN
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); L"|4
v
DataSource ds = (DataSource) ctx.lookup(jndi); xEv]VL:
Connection cn = ds.getConnection(); u l[ edp_
多用于jsp中 U$CAA5HV]
2、执行sql语句 'r`#u@TTZ
1)用Statement来执行sql语句 {m1=#*
String sql; r&F(VF0
6
Statement sm = cn.createStatement(); <>3}<i<[&
sm.executeQuery(sql); // 执行数据查询语句(select) Vgy}0pCl
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); Fkgnc{NI
2)用PreparedStatement来执行sql语句 !OwRx5
String sql; bvyX(^I[q
sql = "insert into user (id,name) values (?,?)"; yZ7aH|Q81B
PreparedStatement ps = cn.prepareStatement(sql); _@U?;73"5
ps.setInt(1,xxx); 2c?-_OCy;
ps.setString(2,xxx); s7j#Yg
... y&8' V\
ResultSet rs = ps.executeQuery(); // 查询 Rou$`<{H
int c = ps.executeUpdate(); // 更新 EOqvu=$6
a/d'(]
3、处理执行结果 .iK{=L/(y
查询语句,返回记录集ResultSet QLNQE 6-
更新语句,返回数字,表示该更新影响的记录数 DRS68^
ResultSet的方法 {&tbp
Bl#
1、next(),将游标往后移动一行,如果成功返回true;否则返回false O'tVZ!C#J
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 #i$/qk=N
R7~H}>uaF
4、释放连接 lwS6"2q
cn.close(); 3`y9V2&b
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection #H]cb#
cYBv}ylw}R
可滚动、更新的记录集 SQ*dC
1、创建可滚动、更新的Statement AhjK*nJF
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); 7.hgne'<
该Statement取得的ResultSet就是可滚动的 /?<tjK' "H
2、创建PreparedStatement时指定参数 *#ccz
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); =HJ)!(
ResultSet.absolute(9000); tqI]S
X
批量更新 th&?
1、Statement Wi a%rm
Statement sm = cn.createStatement(); tI651Wm9
sm.addBatch(sql1); 5sbMp;ZM
sm.addBatch(sql2); V6)e Jy
... :U^!N8i"=
sm.executeBatch() Y\e,#y
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 ]Z/<HP$#
2、PreparedStatement 5nq0#0Oc
PreparedStatement ps = cn.preparedStatement(sql); AvW2)+6G
{ B> kx$_~
ps.setXXX(1,xxx); 4;G:.k!K
... :?1r.n
ps.addBatch(); J*)Vpk
} om$x;L6
ps.executeBatch(); !>$tRW?gH~
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 CD$0Z
XXuIWIhm
事务的处理 sT|$@$bN
1、关闭Connection的自动提交 pJM~'tlHV
cn.setAutoCommit(false); 3#)I 7FG
2、执行一系列sql语句 Tac7+=T
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close JffjGf-o
Statement sm ; N[$bP)h7
sm = cn.createStatement(insert into user...); hrfu\cI
sm.executeUpdate(); *Xh)22~T
sm.close(); /cn=8%!N
sm = cn.createStatement("insert into corp...); S\7-u\)
sm.executeUpdate(); 8KqrB!
sm.close(); @ 2r9JqR[=
3、提交 b21c} rI3
cn.commit(); aA Hx^X^
4、如果发生异常,那么回滚 OnO56,+S^
cn.rollback();