java 数据库基本操作 4EiEE{9V
1、java数据库操作基本流程 %usy`4
2
2、几个常用的重要技巧: ?6gC;B
可滚动、更新的记录集 k%?fy
批量更新 b{KpfbxcI
事务处理 =*aun&
#lM :BO
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 6jiz$x
1、取得数据库连接 jMvWS71
1)用DriverManager取数据库连接 B|-E3v:f4
例子 h<50jnH!
String className,url,uid,pwd; A7!=`yA$
className = "oracle.jdbc.driver.OracleDriver"; }l/!thzC
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; A3C#wJ
uid = "system"; n
4:Yc@,
pwd = "manager"; Wv]NFHe#
Class.forName(className); 4|*H0}HOm
Connection cn = DriverManager.getConnection(url,uid,pwd); MH+t`/E0]
2)用jndi(java的命名和目录服务)方式 '{:WxGgi
例子 , wT$L3
String jndi = "jdbc/db"; 4%TY`
II
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); ]C =+
DataSource ds = (DataSource) ctx.lookup(jndi); &xlz80%
Connection cn = ds.getConnection(); i6p0(OS&D
多用于jsp中 -o\r]24
2、执行sql语句 FL+^r6DQ
1)用Statement来执行sql语句 .FS`Fh;
String sql; vt3yCS
Statement sm = cn.createStatement(); _
FcfNF
sm.executeQuery(sql); // 执行数据查询语句(select) {"dU?/d
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); X#$mBRK7
2)用PreparedStatement来执行sql语句 ,nJYYM
String sql; C%8jWc
sql = "insert into user (id,name) values (?,?)"; ?\C7.of
PreparedStatement ps = cn.prepareStatement(sql); dHnR)[?e
ps.setInt(1,xxx); C< GS._V&
ps.setString(2,xxx); lZ5 lmsCU
... mJaWzR
ResultSet rs = ps.executeQuery(); // 查询 }];8v+M
int c = ps.executeUpdate(); // 更新 +j._NRXRH
o:<gJzg
3、处理执行结果 ,[rh7_
查询语句,返回记录集ResultSet `CP}1W>
更新语句,返回数字,表示该更新影响的记录数 z}vgp\cuT
ResultSet的方法 _h4{Sx
1、next(),将游标往后移动一行,如果成功返回true;否则返回false ]~:9b[G2
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 :?VM1!~ga
E4^zW_|xE
4、释放连接 oe$Y=`
cn.close(); $2=-Q/lM
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection ^Tbw#x]2
lS.*/u*5
可滚动、更新的记录集 1>$fLbmkI
1、创建可滚动、更新的Statement 6>! ;g'k
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); UwuDs2
t
该Statement取得的ResultSet就是可滚动的 _VFxzM9f
2、创建PreparedStatement时指定参数 -z]v"gF?Px
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); %Y"@VcN
ResultSet.absolute(9000); [:geDk9O#'
批量更新 Zk*/~f|\
1、Statement Cf'O*RFD
Statement sm = cn.createStatement(); 8-Ik .,}
sm.addBatch(sql1); je6H}eWTC6
sm.addBatch(sql2); Y]ML-smN
... .`z](s
sm.executeBatch() s7?Q[vN
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 t1,sG8Z
2、PreparedStatement LHjGlBy
PreparedStatement ps = cn.preparedStatement(sql); \vVGfG?6
{ zmH 8#
ps.setXXX(1,xxx); hm=E~wv'L
... ?:(BkY,K5
ps.addBatch(); v%(2l|M
} `}/&}Sp
ps.executeBatch(); {O-,JCq/
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 aZGX`;3
\8%64ZL`
事务的处理 zfDxc3e
1、关闭Connection的自动提交 pCOr{I\
cn.setAutoCommit(false); q(0V#kKC
2、执行一系列sql语句 hX\z93an
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close eqK6`gHa6
Statement sm ; Fv \yhR
sm = cn.createStatement(insert into user...); w)o^?9T
sm.executeUpdate(); d(RSn|[0
sm.close();
GU99!.$
sm = cn.createStatement("insert into corp...); 6@`Y6>}$_
sm.executeUpdate(); xy>~1 5
sm.close(); Zvd^<SP<?
3、提交 ;0Yeo"-
cn.commit(); gbOd(ugH
4、如果发生异常,那么回滚 bKsl'3~ k
cn.rollback();