java 数据库基本操作 #f2Ot<#-
1、java数据库操作基本流程 :wC\IwG~CE
2、几个常用的重要技巧: 7iP+!e}$.
可滚动、更新的记录集 uHg q"e
批量更新 ybBmg'198
事务处理 vjS`;^9
ZxF`i>/h
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 p) 8S]p]
1、取得数据库连接 \Bo%2O%4
1)用DriverManager取数据库连接 ) E^S+ps
例子 TR DQ+Z
String className,url,uid,pwd; w2DC5ei'
className = "oracle.jdbc.driver.OracleDriver"; P.]h`4
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; NrqJf-ldo
uid = "system"; pa>C}jk}6
pwd = "manager"; {kpF etXt?
Class.forName(className); b@Oq}^a&o
Connection cn = DriverManager.getConnection(url,uid,pwd); y :;.r:
2)用jndi(java的命名和目录服务)方式 ot}erC2~
例子 ^&>B,;Wu
String jndi = "jdbc/db"; /|?$C7%a\D
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); igxO:]?
DataSource ds = (DataSource) ctx.lookup(jndi); rwP#Yj[BK+
Connection cn = ds.getConnection(); xp^RAVXq`
多用于jsp中 e5'I W__
2、执行sql语句 eAy,T<#
1)用Statement来执行sql语句 8
lggGt
String sql; gm9*z.S\'
Statement sm = cn.createStatement(); k\f
_\pj6
sm.executeQuery(sql); // 执行数据查询语句(select) &A0OYV3i.
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); W==~9
2)用PreparedStatement来执行sql语句 !..<_qfw
String sql; MmT/J1zM
sql = "insert into user (id,name) values (?,?)"; p D<w@2K
PreparedStatement ps = cn.prepareStatement(sql); Sm'Tz&!
ps.setInt(1,xxx); ofy"SM
ps.setString(2,xxx); X-["{
... TLwxP"
ResultSet rs = ps.executeQuery(); // 查询 2"ax*MQH<^
int c = ps.executeUpdate(); // 更新 ]+D@E2E
(nqry[g&
3、处理执行结果 $+4DpqJ
查询语句,返回记录集ResultSet kdNo<x1o
更新语句,返回数字,表示该更新影响的记录数 :&BPKqKp
ResultSet的方法 rW?WdEg
1、next(),将游标往后移动一行,如果成功返回true;否则返回false <[dcIw<7
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 L `1 ITz
dNe!X0[
4、释放连接 s)-oCT$[
cn.close(); 9?l a5
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection 5JzvT JMx
VF?H0}YSHb
可滚动、更新的记录集 KFrsXf
1、创建可滚动、更新的Statement sfXFh
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); iH(7.?.r
该Statement取得的ResultSet就是可滚动的 J^7m?mA
2、创建PreparedStatement时指定参数 {$frR "K
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); &N}"4
ResultSet.absolute(9000); MPB[~#:
批量更新 }1#m+ (;
1、Statement `J.,dqGb
Statement sm = cn.createStatement(); qDdO-fPev
sm.addBatch(sql1); t'44X
sm.addBatch(sql2); 63fYX"
... ,.)wCZ,wca
sm.executeBatch() Nv5^2^Sc=
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 Pe%[d[k
2、PreparedStatement A]BeI
PreparedStatement ps = cn.preparedStatement(sql); Mq>
4!
{ <pX?x3-'
ps.setXXX(1,xxx); $ f:uBhM
... T@W:@,34
ps.addBatch(); ^6W}ZLp
} @ m`C%7<
ps.executeBatch(); H{}&|;0
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 SEgw!2H
m212
gc0u
事务的处理 j97+'AKX
1、关闭Connection的自动提交 WDc[+Xyw
cn.setAutoCommit(false); ifn=De3+
2、执行一系列sql语句 4=,J@N-
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close o#m31*o
Statement sm ; 0+\725DJ
sm = cn.createStatement(insert into user...); A]bb*a1
sm.executeUpdate(); Z`-$b~0
sm.close(); 1<!P:@(
sm = cn.createStatement("insert into corp...); PZ]tl
sm.executeUpdate(); m
H:Un{,
sm.close(); alJ0gc2?
3、提交 WuK<?1meN
cn.commit(); OX"Na2-el
4、如果发生异常,那么回滚 ai 4 k?
cn.rollback();