java 数据库基本操作 fjUyx:
1、java数据库操作基本流程 Rld1pX2v
2、几个常用的重要技巧: p;dH[NW
可滚动、更新的记录集 a
X >bC-
批量更新 BzqM$F(
L,
事务处理 |pv:'']J
Qa nE]
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 9=D\xBd|w
1、取得数据库连接 pJ6Z/3]
1)用DriverManager取数据库连接 a;Q6S
例子 qV$\.T>x
String className,url,uid,pwd; A0SEzX({[
className = "oracle.jdbc.driver.OracleDriver"; Z-RgN
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; aClXg-
uid = "system"; ic:_v?k
pwd = "manager"; VRYj&s'@
Class.forName(className); n>tYeN)F<
Connection cn = DriverManager.getConnection(url,uid,pwd); sXm/+I^
2)用jndi(java的命名和目录服务)方式 [YY[E 7
例子 x4cP%{n
String jndi = "jdbc/db"; ocCC63J
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); QvK-3w;=
DataSource ds = (DataSource) ctx.lookup(jndi); m4{F-++dk
Connection cn = ds.getConnection(); vdloh ,
多用于jsp中 [q/=%8qLUA
2、执行sql语句 9-Bp =M
1)用Statement来执行sql语句 /O1r=lv3Z
String sql; AF4:v<EN
Statement sm = cn.createStatement(); (^'TT>2B
sm.executeQuery(sql); // 执行数据查询语句(select) RLN>*X
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); Gb6t`dSzz
2)用PreparedStatement来执行sql语句 }g:y!pk
String sql; nz:I\yA
sql = "insert into user (id,name) values (?,?)"; `<Xq@\H
PreparedStatement ps = cn.prepareStatement(sql); #`5{?2gS9
ps.setInt(1,xxx); lzz rzx^
ps.setString(2,xxx); `1F[.DdF
... >&mlwxqv
ResultSet rs = ps.executeQuery(); // 查询 cB
U,!
int c = ps.executeUpdate(); // 更新 vgSs]g
@Iz vObK
3、处理执行结果 %EYh5W
查询语句,返回记录集ResultSet P SDzs\s
更新语句,返回数字,表示该更新影响的记录数 CUgXpU*
ResultSet的方法 G\S\Qe{P~
1、next(),将游标往后移动一行,如果成功返回true;否则返回false ngoo4}
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 O1pBr=+j+{
u+eA>{
4、释放连接 jk2h"):B>
cn.close(); $v?+X20
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection 0 !yvcviw
XJ~_FiB
可滚动、更新的记录集 `y; s1nL
1、创建可滚动、更新的Statement
H
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); ~d :Z|8
该Statement取得的ResultSet就是可滚动的 E.]sX_X?
2、创建PreparedStatement时指定参数 7pDov@K<{
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); je1f\N45
ResultSet.absolute(9000); *R.Q!Lv+
批量更新 TIbqUR
1、Statement jW5n^Y)
Statement sm = cn.createStatement(); "$KU+?
sm.addBatch(sql1); 8;YeEW5
sm.addBatch(sql2); )&}\2NK6L
... {yQeLION
sm.executeBatch() %"~\Pu*>
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 /T`L;YE
2、PreparedStatement "Zd4e2>{M\
PreparedStatement ps = cn.preparedStatement(sql); B#'TF?HUEn
{ TQDb\d8,f
ps.setXXX(1,xxx); [H-,zY
... 1\:puC\)
ps.addBatch(); R{.5Z/Vp6E
} R9Wh/@J]
ps.executeBatch(); e0%?;w-TL
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 _Z'j%/-4@D
})O^xF~
事务的处理 W!pLk/|ls
1、关闭Connection的自动提交 <Y9vc:S
cn.setAutoCommit(false); w4U]lg<}E
2、执行一系列sql语句 7Wb:^.d
g
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close ,Ju f
Statement sm ; qepsR/0M
sm = cn.createStatement(insert into user...); l$D]*_ jc,
sm.executeUpdate(); EotZ$O=
sm.close(); (#FWA<o
sm = cn.createStatement("insert into corp...); n.]K"$230
sm.executeUpdate(); 2'_xg~
sm.close(); }:C4T*|
3、提交 ri&B%AAc
cn.commit(); 2bBTd@m4
4、如果发生异常,那么回滚 L@Fw;G|%'
cn.rollback();