java 数据库基本操作 V07e29w
1、java数据库操作基本流程 # KK>D?.:
2、几个常用的重要技巧: j-ZKEA{:1
可滚动、更新的记录集 D^$Nn*i;U
批量更新 Y&'Bl$`
事务处理 Ns?y)
G>:
dr'#
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 1^TOTY
1、取得数据库连接 v=$v*W
1)用DriverManager取数据库连接 }mzM'9JH
例子 vE^Hk!^
String className,url,uid,pwd; VD#`1g<
className = "oracle.jdbc.driver.OracleDriver"; _0<qS{RW
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; )=8MO-{
uid = "system"; !inonR
pwd = "manager"; *2Il{KOA^
Class.forName(className); UB|f{7~&
Connection cn = DriverManager.getConnection(url,uid,pwd); 8(&Jy RT
2)用jndi(java的命名和目录服务)方式 <H::{
例子 be}^}w=
String jndi = "jdbc/db"; LzEs_B=9
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); +pURF&Pr
DataSource ds = (DataSource) ctx.lookup(jndi); |t5K!?{i
Connection cn = ds.getConnection(); dq?{?~3
多用于jsp中 /:iO:g1
2、执行sql语句 l:5x*QSX
1)用Statement来执行sql语句 ov.7FZ+
String sql; -}_-#L!Q
Statement sm = cn.createStatement(); A
M8bem~
sm.executeQuery(sql); // 执行数据查询语句(select) icLf;@
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); GSj04-T"
2)用PreparedStatement来执行sql语句 ),1MR=
String sql; [Dni>2@0
sql = "insert into user (id,name) values (?,?)"; ~_OtbNj#
PreparedStatement ps = cn.prepareStatement(sql); BR;f!
ps.setInt(1,xxx); q{?Po;\D
ps.setString(2,xxx); |}P4Gr}6
... C%}}~Y
ResultSet rs = ps.executeQuery(); // 查询 B/hL
int c = ps.executeUpdate(); // 更新 o[pv.:w
tEh YQZ
3、处理执行结果 zBg>I=hiG
查询语句,返回记录集ResultSet KAH9?zI)M
更新语句,返回数字,表示该更新影响的记录数 bq{":[a
ResultSet的方法 /X>Fn9mM
1、next(),将游标往后移动一行,如果成功返回true;否则返回false 7m3|2Qv
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 z'OY6
(lBgWz
4、释放连接 ]Ng K(IU
cn.close(); jp?;8rS3
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection X;25G
|>(d^<nR^v
可滚动、更新的记录集 #/!fLU@
1、创建可滚动、更新的Statement ,5J-C!C
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); %v
0 I;t
该Statement取得的ResultSet就是可滚动的 Qvo(2(
2、创建PreparedStatement时指定参数 S3EM6 `q'
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); ~$xLR/{y
ResultSet.absolute(9000); e}>8rnR{
批量更新 )bN|*Bw3
1、Statement rK 9
Statement sm = cn.createStatement(); C":i56
sm.addBatch(sql1); X-,scm
sm.addBatch(sql2); +iKs)s_~
... VQA}! p
sm.executeBatch() 1|/P[!u
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 T;!7GW4E
?
2、PreparedStatement GPP{"6q5'
PreparedStatement ps = cn.preparedStatement(sql); <