java 数据库基本操作 !$Aijd s5
1、java数据库操作基本流程 #=F"PhiX`
2、几个常用的重要技巧: )OQhtxK
可滚动、更新的记录集 WeDeD\zy
批量更新 maAZI-H{
事务处理 {6{y"8
&7Frg`B&:
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 AzAD76iNv
1、取得数据库连接 \$:KfN>WY
1)用DriverManager取数据库连接 F x,08
例子 ~f=~tN)hZ
String className,url,uid,pwd; jJFWPD]u
className = "oracle.jdbc.driver.OracleDriver"; <i{O\K]9
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; N<lejZ}!q
uid = "system"; w1HE^
/
pwd = "manager"; rt">xVl
Class.forName(className); 7pMl:\
Connection cn = DriverManager.getConnection(url,uid,pwd); 3 i<,#FaL
2)用jndi(java的命名和目录服务)方式 ?xEQ'(UBQ
例子 /~3~Xc~=p
String jndi = "jdbc/db"; (Mi]vK.4
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); Y.`
{]rC
DataSource ds = (DataSource) ctx.lookup(jndi); Y<|!)JLB2
Connection cn = ds.getConnection(); S\fEV"
多用于jsp中 3sG7G:4
2、执行sql语句
aEUC
1)用Statement来执行sql语句 Fe
3*pUt
String sql; }L
Q9db1
Statement sm = cn.createStatement(); /2}o:vLj
sm.executeQuery(sql); // 执行数据查询语句(select) 1HQh%dZZ
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); ?#8',:
2)用PreparedStatement来执行sql语句 r~cmrLQa
String sql; #qkokV6`
sql = "insert into user (id,name) values (?,?)"; ZeewGa^r
PreparedStatement ps = cn.prepareStatement(sql); $YZsaw
ps.setInt(1,xxx); lv
-z[
ps.setString(2,xxx); 1d/-SxhZ
... AA][}lU:5
ResultSet rs = ps.executeQuery(); // 查询 z _qy>
int c = ps.executeUpdate(); // 更新 ~\= VSwJ
[A$5~/Q{U1
3、处理执行结果 &v!=\Fig4
查询语句,返回记录集ResultSet pR_cI]{=SA
更新语句,返回数字,表示该更新影响的记录数 FTM(y CN
ResultSet的方法 KrOoxrDcp
1、next(),将游标往后移动一行,如果成功返回true;否则返回false dw
%aoe
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 f[,9WkC
vZV+24YWb
4、释放连接 D|8vS8p
cn.close(); <viIpz2jh%
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection u@|izRk
aE}1~`
可滚动、更新的记录集 mk>L:+
1、创建可滚动、更新的Statement -H1mKZDPP
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); 2p\CCzw
该Statement取得的ResultSet就是可滚动的 O%)@> 5#S
2、创建PreparedStatement时指定参数 4d&#NP
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); Pn@k)g
ResultSet.absolute(9000); %bI(
批量更新 |8I #`
1、Statement 8r
'
Statement sm = cn.createStatement(); .DSn
H6O
sm.addBatch(sql1); (IXiwu
sm.addBatch(sql2); ^l1tQnj)7
... =H*}{'#
sm.executeBatch() F#=XJYG1
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 t~pA2?9@
2、PreparedStatement {MmHR
PreparedStatement ps = cn.preparedStatement(sql); `@GqD
{ >cwyb9;!kK
ps.setXXX(1,xxx); Z09FW>"u
... K/RQ-xd4
ps.addBatch(); H5t 9Mg|
} (H *-b4]/
ps.executeBatch(); "8K>Yu17
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 M=[ /v/M=
2m.RM&TdB
事务的处理 H
<CsB
1、关闭Connection的自动提交 QX(x6y>Q
cn.setAutoCommit(false);
#.O,JG#H
2、执行一系列sql语句 :T~Aa(%(
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close /UeLf$%ZW
Statement sm ; -1Y9-nn[m
sm = cn.createStatement(insert into user...); PoMkFG6
sm.executeUpdate(); ps0wN%tA
sm.close(); f`<j(.{9F
sm = cn.createStatement("insert into corp...); N[4v6GS
sm.executeUpdate(); 8+vZ9!7
sm.close(); L'{;V\d
3、提交 A.7:.5Cx'
cn.commit(); 'B}pIx6k~
4、如果发生异常,那么回滚 f@l 6]z{.L
cn.rollback();