java 数据库基本操作 ?X5Y8n]y\h
1、java数据库操作基本流程 >J,y1jzJ
2、几个常用的重要技巧: #cdrobJ
可滚动、更新的记录集 ~;uc@GGo
批量更新 ^oYudb^%
事务处理 unZYFA}(
yhzZ[vw7k
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 ey ; 94n:<
1、取得数据库连接 UD}#c:I
1)用DriverManager取数据库连接 Z:3SI$tO
例子 '#Pg:v_
String className,url,uid,pwd; /.>8e%)
className = "oracle.jdbc.driver.OracleDriver"; (W'.vEl
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; iB0#Z_
uid = "system"; G>>TB{}
pwd = "manager"; &w7Ev21
Class.forName(className); `%oJa`
Connection cn = DriverManager.getConnection(url,uid,pwd); 2n|]&D3V"'
2)用jndi(java的命名和目录服务)方式 5wgeA^HE2y
例子 ~+OAAkJ9
String jndi = "jdbc/db"; -H-:b7
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); tQSJ"Q
DataSource ds = (DataSource) ctx.lookup(jndi); *uG!U%jY)
Connection cn = ds.getConnection(); (#?k|e"Y"`
多用于jsp中 X+LG Z4]D
2、执行sql语句 K#_x.:<J
1)用Statement来执行sql语句 j$ h>CZZ
String sql; Oiz@tEp=_
Statement sm = cn.createStatement(); PTZ/jg@71
sm.executeQuery(sql); // 执行数据查询语句(select) NuQ
l
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); <)am]+Lswy
2)用PreparedStatement来执行sql语句 @})]4H
String sql; L$rMfeS
sql = "insert into user (id,name) values (?,?)"; ]R?{9H|jwE
PreparedStatement ps = cn.prepareStatement(sql); %f'mW2
ps.setInt(1,xxx); E=eK(t(8
ps.setString(2,xxx); q47:kB{d
... .XTR
HL*:
ResultSet rs = ps.executeQuery(); // 查询 P|'eM%
int c = ps.executeUpdate(); // 更新 yNc"E
{$H-7-O$
3、处理执行结果 mA2L~=v#
查询语句,返回记录集ResultSet yDe6f(D
更新语句,返回数字,表示该更新影响的记录数 pB0p?D)n
ResultSet的方法 O~~WP*N
1、next(),将游标往后移动一行,如果成功返回true;否则返回false kACgP!~/1
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 <g3)!VR^q
% 8hjMds
4、释放连接 05PRlz*x=
cn.close(); P~d&PhOe
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection x4=Sm0Ro|V
6#gS`X23Y
可滚动、更新的记录集 d.Im{-S
1、创建可滚动、更新的Statement aTL u7C\-e
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); pEp`Z,p
该Statement取得的ResultSet就是可滚动的 2*)2c[/0F
2、创建PreparedStatement时指定参数 K~6,xZlDWM
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); VxA?LS`
ResultSet.absolute(9000); Ql8s7 %
批量更新 Vz
@2_k
1、Statement vmsrypm
Statement sm = cn.createStatement(); %pG^8Q()
sm.addBatch(sql1); [ ~&yLccN
sm.addBatch(sql2); ~OSgpM#O!T
... 1=U NA :t<
sm.executeBatch() 68 \73L=
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 hI>vz"J
2、PreparedStatement qSA]61U&
PreparedStatement ps = cn.preparedStatement(sql); u/_TR;u=q
{ ;U)xZ _Ew~
ps.setXXX(1,xxx); 3Z%~WE;I
... W{W8\
ps.addBatch(); }p|S3/G?$!
} 2&o
jQhe
ps.executeBatch(); I 6-.;)McO
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 0ub0[A
0aM&+j\q}
事务的处理 pB5#Ho>S
1、关闭Connection的自动提交 ATzFs]~K;
cn.setAutoCommit(false); )sZJH9[K
2、执行一系列sql语句 ?DrA@;IB
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close =8V
9E
Statement sm ; Cno+rmsfT
sm = cn.createStatement(insert into user...); 1Wr,E#+C
sm.executeUpdate();
kJ[r.)HU
sm.close(); @
Cd#\D|
sm = cn.createStatement("insert into corp...); }5]2tH${
sm.executeUpdate(); A~)#
sm.close(); AC&)FY
3、提交 %iR"eEE
cn.commit(); a${<~M
hm
4、如果发生异常,那么回滚 ^gSZzJ5
cn.rollback();