java 数据库基本操作 UzXE_S
1、java数据库操作基本流程 qwIa?!8o
2、几个常用的重要技巧: U4 13?Pe
可滚动、更新的记录集 'J,T{s1J
批量更新 J_>w 3uY
事务处理 >^Se'SE]
Hm+ODv9
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 D")_;NLE1
1、取得数据库连接 Zy|Mz&
1)用DriverManager取数据库连接 RI68%ZoL
例子 mv5n4mav
String className,url,uid,pwd; V5p=
mmnA,
className = "oracle.jdbc.driver.OracleDriver"; :>p8zG
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; 3Tn)Z1o
uid = "system"; 5 H#W[^s"
pwd = "manager"; YeF1C/'hy
Class.forName(className); GTHkY*
Connection cn = DriverManager.getConnection(url,uid,pwd); 0afei4i~N
2)用jndi(java的命名和目录服务)方式 a0Ik`8^`
例子 Fg Lrb#
String jndi = "jdbc/db"; 1?
FrJ6V
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); s7oT G!
DataSource ds = (DataSource) ctx.lookup(jndi); *^([ ~[
Connection cn = ds.getConnection(); ',GS#~
多用于jsp中 "5eNLqt^q
2、执行sql语句 Q}S_%I}u:
1)用Statement来执行sql语句 qF 9NQ;
String sql; k</%YKk
Statement sm = cn.createStatement(); s?ko?qN(
sm.executeQuery(sql); // 执行数据查询语句(select) _|"Y]:j_
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); -l%J/ :
2)用PreparedStatement来执行sql语句 |+`c3*PV
String sql; ~rjTF!
sql = "insert into user (id,name) values (?,?)"; 5OoN!TEM
PreparedStatement ps = cn.prepareStatement(sql); }du XC[ 6
ps.setInt(1,xxx); N)&4Hy
ps.setString(2,xxx); >DPB!XA3
... OgF+OS
ResultSet rs = ps.executeQuery(); // 查询 w
'3#&k+
int c = ps.executeUpdate(); // 更新 gKOOHUCb
9b?SHzAa
3、处理执行结果 nenU)*o
查询语句,返回记录集ResultSet Mwgu93?
更新语句,返回数字,表示该更新影响的记录数 lo'W1p
ResultSet的方法 \,J/ r!
1、next(),将游标往后移动一行,如果成功返回true;否则返回false = waA`Id
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 ~tOAT;g}q
iD= p\
4、释放连接 >Z1q j>
cn.close(); \6;=$f/?t
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection 4mn&4e
;Jd3u
-
可滚动、更新的记录集 6\61~u ~
1、创建可滚动、更新的Statement I|# 5NE6
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); lY*[tmz)
该Statement取得的ResultSet就是可滚动的 UX]L;kI
2、创建PreparedStatement时指定参数 +:3*
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); gIA@l`"
ResultSet.absolute(9000); sBV4)xM
批量更新 w&xDOyW]
1、Statement O$IjNx
Statement sm = cn.createStatement(); 3BpZX`l*p
sm.addBatch(sql1); D~o$GW%
sm.addBatch(sql2); yjJ5P`j]
... /O]t R
sm.executeBatch() n ]dL?BJ
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 pH`44KAuM
2、PreparedStatement @-OnHE
PreparedStatement ps = cn.preparedStatement(sql); KRjV}\}
{ 4e;QiTj
ps.setXXX(1,xxx); =}PdH`S
... BcD&sQ2F
ps.addBatch(); )]#aa uC+
} Z@Ae$ '9H
ps.executeBatch(); wu"&|dt
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 b=3H
c*UvYzDZL
事务的处理 qH['09/F6
1、关闭Connection的自动提交 X*,Kb(3
cn.setAutoCommit(false); =!m}xdTP
2、执行一系列sql语句 u !!X6<
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close $ cu00K
Statement sm ; Zs<KZGn-B
sm = cn.createStatement(insert into user...); 0zY(:;X
sm.executeUpdate(); w>b-} t
sm.close(); JJRK7\~$
sm = cn.createStatement("insert into corp...); <9>vO,n
sm.executeUpdate(); ]:34kE}e5
sm.close(); kp\\"+,VC
3、提交 ["}rk
cn.commit(); T)\"Xj
4、如果发生异常,那么回滚 2 1PFR:lP7
cn.rollback();