java 数据库基本操作 ywl7bU-f
1、java数据库操作基本流程 D_(K{?KU
2、几个常用的重要技巧: 1}#RUqFrvS
可滚动、更新的记录集 2{gd4Kt6.
批量更新 d$O)k+j
事务处理 [-pB}1Dxb
3L5o8?[
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 Ze:Y"49S+>
1、取得数据库连接 'aAay*1
1)用DriverManager取数据库连接 rf:CB&u
例子 Jemb0Qv
String className,url,uid,pwd; Z^?Y TykH
className = "oracle.jdbc.driver.OracleDriver"; ~p'DPg4
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; S^/:O.X)c,
uid = "system"; J]=2] oI2
pwd = "manager"; w?db~"T
Class.forName(className); FE[{*8
Connection cn = DriverManager.getConnection(url,uid,pwd); 6lKM5,Oa
2)用jndi(java的命名和目录服务)方式 M,f|.p{,Y
例子 .:(N1n'>1
String jndi = "jdbc/db"; `& (Fy
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); NW=tZV Q<X
DataSource ds = (DataSource) ctx.lookup(jndi); uJX(s6["=
Connection cn = ds.getConnection(); H{4/~Z
多用于jsp中 d J;y>_
2、执行sql语句 aDreN*n
1)用Statement来执行sql语句 Dn9AOi!
String sql; /[|ODfY
Statement sm = cn.createStatement(); .}6Mj]7?i
sm.executeQuery(sql); // 执行数据查询语句(select) DX$zzf
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); qt
!T%K
2)用PreparedStatement来执行sql语句 Wt8=j1>
String sql; A8by5qU
sql = "insert into user (id,name) values (?,?)"; R/UL4R,)^
PreparedStatement ps = cn.prepareStatement(sql); -1P*4H2a
ps.setInt(1,xxx); ^ 1 P@BRh
ps.setString(2,xxx); n!>#o1Qr
... ?4&C)[^
ResultSet rs = ps.executeQuery(); // 查询 1MF0HiC
int c = ps.executeUpdate(); // 更新 61}hB>TT:
(wtw1E5X
3、处理执行结果 ^9zFAY.|
查询语句,返回记录集ResultSet h+!
更新语句,返回数字,表示该更新影响的记录数 a|s64+
ResultSet的方法 HN j6Iw
1、next(),将游标往后移动一行,如果成功返回true;否则返回false 3|FZ!8D
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 z$q:Yg
$kM8E@x2
4、释放连接 uSRvc0R\
cn.close(); 'J=knjAT
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection CaV>\E)
#FHyP1uyc
可滚动、更新的记录集 PM
A61g
1、创建可滚动、更新的Statement s,2gd'
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); =IkG;gg
该Statement取得的ResultSet就是可滚动的 e=<%{M&
2、创建PreparedStatement时指定参数 >dTJ
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); ,cqZb0VP{t
ResultSet.absolute(9000); mI[$c"!BD
批量更新 |k-IY]6
1、Statement :d5fU:
Statement sm = cn.createStatement(); N+[ |"v
sm.addBatch(sql1); D]h~\
sm.addBatch(sql2); = Nd&My
... 6}>:sr
sm.executeBatch() -1>$3-ur~
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 8UANB]@Y}
2、PreparedStatement s7~[7
PreparedStatement ps = cn.preparedStatement(sql); DwL4?!E
{ ; {P"~(S%
ps.setXXX(1,xxx); 1 =cFV'
... PilV5Gg
ps.addBatch(); %N, P?
,U
}
7z?rx
ps.executeBatch(); I}@m6D|\
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 )7j CEA03
M-B -
事务的处理 Yiq8>|
1、关闭Connection的自动提交 s=uWBh3J
cn.setAutoCommit(false); h{sY5d'D
2、执行一系列sql语句 q[}[w! to
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close b)eKa40Z
Statement sm ;
A`D^}F6
sm = cn.createStatement(insert into user...); t#p*{S 3u
sm.executeUpdate(); hjgxCSp
sm.close(); -'sn0_q/e
sm = cn.createStatement("insert into corp...); );cu{GY
sm.executeUpdate(); vX'@we7Q{
sm.close(); %ys-y?r
3、提交 pNHO;N[&
cn.commit(); >^ E
4、如果发生异常,那么回滚 kr_!AW<.tz
cn.rollback();