java 数据库基本操作 xQs2)
1、java数据库操作基本流程 FY"!%)TV
2、几个常用的重要技巧: v ?@Ys+V
可滚动、更新的记录集 H?8uy_Sc
批量更新 "Yw-1h`fR
事务处理 )W9$_<Z
@ -pi
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 O?Xg%k#
1、取得数据库连接 +=I_3Wtth
1)用DriverManager取数据库连接 btb-MSkO
例子 {xr!H-9ZAA
String className,url,uid,pwd; A
S;ra,x
className = "oracle.jdbc.driver.OracleDriver"; M@@"-dy
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; Y<Y5HI"
uid = "system"; Cec!{]DL&
pwd = "manager"; jTk !wm=
Class.forName(className); *g&[?y`UC
Connection cn = DriverManager.getConnection(url,uid,pwd); mJb>)bOl
2)用jndi(java的命名和目录服务)方式 R:YX{Tq
例子 (PU0\bGA
String jndi = "jdbc/db"; (_-<3)q4
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); >69xl^Gd
DataSource ds = (DataSource) ctx.lookup(jndi); y6Xfddd61
Connection cn = ds.getConnection(); M$A"<5
多用于jsp中 M=n!tVlCV
2、执行sql语句 SiHZco
I
1)用Statement来执行sql语句 Md'd=Y_0
String sql; P7d" E
Statement sm = cn.createStatement(); msg&~"Z
sm.executeQuery(sql); // 执行数据查询语句(select) AR'q2/cw
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); mJ0nyjX^
2)用PreparedStatement来执行sql语句 s&Y~48{
String sql; {y=H49
sql = "insert into user (id,name) values (?,?)"; 'wz*GMGWC
PreparedStatement ps = cn.prepareStatement(sql); F>&Q5Kl R
ps.setInt(1,xxx); oH!sJ&"#_
ps.setString(2,xxx); -tZ2
N
... DIodQkF
ResultSet rs = ps.executeQuery(); // 查询 "v4;m\g&:
int c = ps.executeUpdate(); // 更新 [qlq& ?"
]OZZPo
3、处理执行结果 ftF?T.dx
查询语句,返回记录集ResultSet g;w4:k)U
更新语句,返回数字,表示该更新影响的记录数 F6Z l#eL
ResultSet的方法 `ysPEwA|
1、next(),将游标往后移动一行,如果成功返回true;否则返回false w(n&(5FzB<
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 -QCo]:cp
!TP8LQ
4、释放连接 z^I"{eT8
cn.close(); 2fTkHBhn&
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection 2#C!40j&\
G+AD
&EHV
可滚动、更新的记录集 pmB}a7
1、创建可滚动、更新的Statement -vwkvNn8
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); ukv
_bw
该Statement取得的ResultSet就是可滚动的 #*#4vMk<
2、创建PreparedStatement时指定参数 E*>tFw&[
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); o+`W
ResultSet.absolute(9000); lYT}Nc4"="
批量更新 :1eI"])(
1、Statement -% PUY(
Statement sm = cn.createStatement(); r0l ud&_9
sm.addBatch(sql1); xeo;4c#S5
sm.addBatch(sql2); iyU@|^B"Wa
... S20x
sm.executeBatch() k!t5>kPSQ
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 Mkko1T=6
2、PreparedStatement j[m\;3Sp
PreparedStatement ps = cn.preparedStatement(sql); D}vgXzD
{ +|r;t
ps.setXXX(1,xxx); r^_8y8&l
... !0c7nzjm
ps.addBatch(); >BMJA:j
} &5Ea6j
ps.executeBatch(); cQzd0X
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 9c9-1iS
vLDMa>
事务的处理 2V/A%
1、关闭Connection的自动提交 ;gy_Q f2U
cn.setAutoCommit(false); .}kUD]pW
2、执行一系列sql语句 kOETx
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close >#*]/t
Statement sm ; X<K[`
=I
sm = cn.createStatement(insert into user...); 03J,NXs
sm.executeUpdate(); pK1P-!c
sm.close(); qi`*4cas*A
sm = cn.createStatement("insert into corp...); 2W|4
sm.executeUpdate(); *58<.L|
sm.close(); @jN!j*Y H
3、提交 yopEqO
cn.commit(); FoWE<
4、如果发生异常,那么回滚 Thn-8DT
cn.rollback();