java 数据库基本操作 ^B]@Lr E^
1、java数据库操作基本流程 uMd. j$$
2、几个常用的重要技巧: BJy;-(JP
可滚动、更新的记录集 +>tUz D
批量更新 Fr [7
事务处理 ?fK1
BC7 7<R!E)
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 \Y5W!.(%w
1、取得数据库连接 !Zjq9{t\"
1)用DriverManager取数据库连接 GBQn_(b9I
例子 /tj$luls5
String className,url,uid,pwd; ;;#`#v
className = "oracle.jdbc.driver.OracleDriver"; _A'{la~k
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; z 7T0u.4Ss
uid = "system"; tC)6
pwd = "manager"; L0"~[zB]N
Class.forName(className); ~x]9SXD%
Connection cn = DriverManager.getConnection(url,uid,pwd); Dl,`\b@Fw3
2)用jndi(java的命名和目录服务)方式 2*1ft>Uty
例子 RN9;kB)c
String jndi = "jdbc/db"; RUo9eQIPD
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); fY W|p<Q0
DataSource ds = (DataSource) ctx.lookup(jndi); 4XJiIa?
Connection cn = ds.getConnection(); Gquuy7[&
多用于jsp中 @~:8ye
2、执行sql语句 mYv(R!37'
1)用Statement来执行sql语句 Z :nbZHByh
String sql; /nQ`&q
Statement sm = cn.createStatement(); s([dGD$i
sm.executeQuery(sql); // 执行数据查询语句(select) VW<0Lt3
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); @_yoX(.E&
2)用PreparedStatement来执行sql语句 caq} &A]C
String sql; tef^ShF]
sql = "insert into user (id,name) values (?,?)";
QG3&p<
PreparedStatement ps = cn.prepareStatement(sql); !mnUdR|>(
ps.setInt(1,xxx); D1T@R)j
ps.setString(2,xxx); #b)e4vwCq
... 7~UR!T9
ResultSet rs = ps.executeQuery(); // 查询 'i|rjW(
int c = ps.executeUpdate(); // 更新 eV};9VJ$F
.*5 Z"Q['G
3、处理执行结果 >)**khuP7
查询语句,返回记录集ResultSet ELD!{bMT
更新语句,返回数字,表示该更新影响的记录数 JAjku6
ResultSet的方法 \ |!\V
1、next(),将游标往后移动一行,如果成功返回true;否则返回false K$[$4 dX]
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 U[\Vj_?(I
z5 m>H;P
4、释放连接 wkb$^mU
cn.close(); A9:NKY{z
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection uGVy6,
Da1aI]{I
可滚动、更新的记录集 I'!/[\_
1、创建可滚动、更新的Statement MaY682}|y
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); v"O5u%P
该Statement取得的ResultSet就是可滚动的 e2)autBe
2、创建PreparedStatement时指定参数 I4c!m_sr
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); <L0#O(L
ResultSet.absolute(9000); r4XH =
批量更新 G|
m4m.
1、Statement H9 tXSh
Statement sm = cn.createStatement(); A\sI<WrH
sm.addBatch(sql1); 7hw .B'7
sm.addBatch(sql2); ^{yk[tHpS
... nk=$B(h
sm.executeBatch() \2e0|)aF6
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 zGlZ!t:
2、PreparedStatement L}k/9F.5
PreparedStatement ps = cn.preparedStatement(sql); G}zZQy
{ pdVQ*=c?M
ps.setXXX(1,xxx); 3Ofc\
... m`A%
p
ps.addBatch(); w=7L3AW
} E-2eOT
ps.executeBatch(); @{HrJ/4%:&
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 aUopNmN
vqdX^m^PY
事务的处理 obH;g*
1、关闭Connection的自动提交 47>>4_Hz
cn.setAutoCommit(false); DXR:1w[^
2、执行一系列sql语句 ~$,qgf
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close 4'>1HW
Statement sm ; _lxco=qd=%
sm = cn.createStatement(insert into user...); j? i#L}.I
sm.executeUpdate(); S?0$? w?
sm.close(); oF&l-DHp
sm = cn.createStatement("insert into corp...); ,. EBOUW^
sm.executeUpdate(); #ToK$8
sm.close(); au@a8MP
3、提交 <i. apBH
cn.commit(); {S.>BXX
4、如果发生异常,那么回滚 V"KS[>>f
cn.rollback();