java 数据库基本操作 ',7a E@PJ
1、java数据库操作基本流程 ?~J i-{#X
2、几个常用的重要技巧: K UKACUL
可滚动、更新的记录集 [E7MsX
批量更新 H3, ut
事务处理 8-m
3e
K/txD20
O|
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 ~2@Lx3t$
1、取得数据库连接 (9 sIA*,}
1)用DriverManager取数据库连接 jNA1O68N
例子 |~WYEh
String className,url,uid,pwd; {T=52h=e
className = "oracle.jdbc.driver.OracleDriver"; >c4/?YV
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; .h4\{|
uid = "system"; 4*TmlY
pwd = "manager"; qTT,U9]:
Class.forName(className); Tk*w3c"$
Connection cn = DriverManager.getConnection(url,uid,pwd); WF2NG;f=
2)用jndi(java的命名和目录服务)方式 rAb&I"\ZY
例子 >O#grDXb
String jndi = "jdbc/db"; Ha%F"V*
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); 2?W7I/F
DataSource ds = (DataSource) ctx.lookup(jndi); 5r b-U7 /
Connection cn = ds.getConnection(); 9'nH2,_
多用于jsp中 )0k']g5
2、执行sql语句 o:"anHs
1)用Statement来执行sql语句 :P$#MC
String sql; 6.5wZN9<|
Statement sm = cn.createStatement(); =>|C~@C?
sm.executeQuery(sql); // 执行数据查询语句(select) $d/&k`
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); (&[[46
2)用PreparedStatement来执行sql语句 z
x@$RS+]
String sql; "7,FXTaer
sql = "insert into user (id,name) values (?,?)"; d--'Rn5
PreparedStatement ps = cn.prepareStatement(sql); nPN?kO=]
ps.setInt(1,xxx); JN4fPGbV
ps.setString(2,xxx); paW@\1Q
... :=Kx/E:1
ResultSet rs = ps.executeQuery(); // 查询 n((vY.NDV
int c = ps.executeUpdate(); // 更新 KL [ek
5|I55CTx
3、处理执行结果 G_ >G'2
查询语句,返回记录集ResultSet FY'ty@|_s
更新语句,返回数字,表示该更新影响的记录数 2 rN ,D(
ResultSet的方法 "B{ECM;
1、next(),将游标往后移动一行,如果成功返回true;否则返回false 0:=ZkEEeU
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 l>6@:nq|R
x[(?#
4、释放连接 ,+`HQdq
cn.close(); rY0u|8.5Q
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection + H_WlYg-
+*}{`L-
:
可滚动、更新的记录集 ;
A,#;%j
1、创建可滚动、更新的Statement /KCPpERk{
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); Nc)J18
该Statement取得的ResultSet就是可滚动的 6GAaV[])'
2、创建PreparedStatement时指定参数 n6MM5h/#r
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); `_vB+a
ResultSet.absolute(9000); V0*3;n
批量更新 c~=B0K-
1、Statement =JS;;PzX[
Statement sm = cn.createStatement(); y
"w|g~x]c
sm.addBatch(sql1); (;_FIUz0
sm.addBatch(sql2); J=W0Xi!
... ;sPoUn
s'
sm.executeBatch() 9H0Hu]zM
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 $HJTj29/
2、PreparedStatement {Qv>q$Q
PreparedStatement ps = cn.preparedStatement(sql); @+LfQY
{ $t~@xCi]S
ps.setXXX(1,xxx); ememce,Np
... <7_KeOLJ
ps.addBatch(); l?8M
p$M
} 5J2=`=FK
ps.executeBatch(); 1ocJ+
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 )$Mmn
B,WTHU[AV
事务的处理 BvD5SBa}"
1、关闭Connection的自动提交 $wB^R(f@
cn.setAutoCommit(false); C?4JXW
2、执行一系列sql语句 d[D&J
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close 1oLv.L
Statement sm ; D*PYr{z'
sm = cn.createStatement(insert into user...); O81X;JdP3
sm.executeUpdate(); errH>D~
sm.close(); &fC!(Oy
sm = cn.createStatement("insert into corp...); DZS]AC*
sm.executeUpdate(); BYrZEVM9
sm.close(); :1ecx$
3、提交 !y:%0{l
cn.commit(); @|}BXQNd
4、如果发生异常,那么回滚 +|iYg/2
cn.rollback();