java 数据库基本操作 ,
udTvI
1、java数据库操作基本流程 W-?()dX{
2、几个常用的重要技巧: y5*Z3"<
可滚动、更新的记录集 =a@j=
批量更新 x{n`^;Y1
事务处理 l5Gq|!2yxD
P<X\%_Iat
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 n1ly
y0%u
1、取得数据库连接 '>cKH$nVC}
1)用DriverManager取数据库连接 95A1:A^t
例子 * +"9%&?
String className,url,uid,pwd; 2jR r,Nl
className = "oracle.jdbc.driver.OracleDriver"; /OLFcxEWh
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; =cm~vDl[
uid = "system"; lku[dQdk
pwd = "manager"; Ye2 {f"F
Class.forName(className); |=`~-i2W
Connection cn = DriverManager.getConnection(url,uid,pwd); /aZ+T5O
2)用jndi(java的命名和目录服务)方式 aMWmLpv4'
例子 zO ).T
M_
String jndi = "jdbc/db"; p i
%<Sy
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); {^CY..3
A
DataSource ds = (DataSource) ctx.lookup(jndi); G6/p1xy>o:
Connection cn = ds.getConnection(); |iE50,
多用于jsp中 dQV;3^iUY
2、执行sql语句 DW5Y@;[
1)用Statement来执行sql语句 [|(N_[E|6
String sql; Tn*9lj4
Statement sm = cn.createStatement(); pWK(z[D
sm.executeQuery(sql); // 执行数据查询语句(select) /&
Jan:
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); x[h^[oF0
2)用PreparedStatement来执行sql语句 bwD,YC
String sql; S ?{#r
sql = "insert into user (id,name) values (?,?)"; pA9+Cr!0Q
PreparedStatement ps = cn.prepareStatement(sql); &7PG.Ff!r
ps.setInt(1,xxx); eJxw)zd7
ps.setString(2,xxx); qf!p 9@4F[
... YH vLGc%
ResultSet rs = ps.executeQuery(); // 查询 oU056
int c = ps.executeUpdate(); // 更新 g!lWu[d
:S<f?*
}:
3、处理执行结果 gl\\+VyU
查询语句,返回记录集ResultSet /?@3.3sl_
更新语句,返回数字,表示该更新影响的记录数 iBF|&h(\
ResultSet的方法 %?}33yV
1、next(),将游标往后移动一行,如果成功返回true;否则返回false i~I%D%;
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 fVF2-Rh=
n>ULRgiT:o
4、释放连接 yeXx',]a
cn.close(); A
mNW0.}
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection 5ymk\Lw
piPR=B+
可滚动、更新的记录集 AgS7J(^&3
1、创建可滚动、更新的Statement \fG#7_wt
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); g)#W>.Asd
该Statement取得的ResultSet就是可滚动的 iII=;:p
2、创建PreparedStatement时指定参数 )wC?T
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); }& cu/o4
ResultSet.absolute(9000); uJzG|$;
批量更新 @ ;*Ksy@1O
1、Statement (s.0PO`
Statement sm = cn.createStatement(); OGK}EI
sm.addBatch(sql1); ,]9P{k]O
sm.addBatch(sql2); 9oYgl1}d
... * @ 3Ag(
sm.executeBatch() w,#>G07D
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 em,u(#)&
2、PreparedStatement "i y
PreparedStatement ps = cn.preparedStatement(sql); %zG;Q@
{ 8(pp2r lR
ps.setXXX(1,xxx); 1S{D6#bE
... &"yx<&c}
ps.addBatch(); y0sR6TY)f
} Uwf+
ps.executeBatch(); `[f*Zv w
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 L
6c 40
[@VP?74
事务的处理 */sS`/Lx
1、关闭Connection的自动提交 ojcA<60
'
cn.setAutoCommit(false); K"|l@Q[
2、执行一系列sql语句 [xSF6
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close .~~nUu+M
Statement sm ; 8&GBV_`I
sm = cn.createStatement(insert into user...); !%CWZZ 6u
sm.executeUpdate(); g;pcZ9o
sm.close(); iW$_zgN
sm = cn.createStatement("insert into corp...); d' !]ZWe
sm.executeUpdate(); A,JmX
sm.close(); W0dSsjNio
3、提交 zZL6z4g
cn.commit(); .c8g:WB<
4、如果发生异常,那么回滚 k.uH~S _
cn.rollback();