java 数据库基本操作 MPM_/dn-
1、java数据库操作基本流程 p?6w/ n
2、几个常用的重要技巧: .,tf[w 71
可滚动、更新的记录集 NV*t
批量更新 ,4EE9
?J
事务处理 5TzMv3;in2
kO/dZ%vj
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 Av+R~&h
1、取得数据库连接 O%
9~1_
1)用DriverManager取数据库连接 97<Y.
0
例子 Hyc19|
String className,url,uid,pwd;
W)j/[
className = "oracle.jdbc.driver.OracleDriver"; FDpNM\SR1l
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; DAc jx:~
uid = "system"; /z5j.TMs
pwd = "manager"; qRB&R$
Class.forName(className); <qv:7@
Connection cn = DriverManager.getConnection(url,uid,pwd); oh,Nu_!
2)用jndi(java的命名和目录服务)方式 IsnC_"f
例子 se7_:0+w
String jndi = "jdbc/db"; L3i\06M
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); U
.G*C
DataSource ds = (DataSource) ctx.lookup(jndi); "64pVaT4
Connection cn = ds.getConnection(); <R_3;5J%
多用于jsp中 fa"eyBO50
2、执行sql语句 E)>6}0P
1)用Statement来执行sql语句 ]$KH78MTW
String sql; /5zzzaj{
Statement sm = cn.createStatement(); kw?RUt0-V
sm.executeQuery(sql); // 执行数据查询语句(select) |p3]9H
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); Rp9uUJ 6o
2)用PreparedStatement来执行sql语句 k6G23p[9
String sql; l3(k
sql = "insert into user (id,name) values (?,?)"; VZw( "a*TB
PreparedStatement ps = cn.prepareStatement(sql); (3=. 3[
ps.setInt(1,xxx); 9u"im+=:
ps.setString(2,xxx); Mt-y{*6!k
... :t9(T?2
ResultSet rs = ps.executeQuery(); // 查询 H6e^"E
int c = ps.executeUpdate(); // 更新 Q/0;r{@Tq}
)3z.{.F
3、处理执行结果
31J7# S2
查询语句,返回记录集ResultSet IKAF%0[R|j
更新语句,返回数字,表示该更新影响的记录数 cUS2*7h
ResultSet的方法 `(Ei-$
>U&
1、next(),将游标往后移动一行,如果成功返回true;否则返回false 6n;ew l}
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 @(Q4
42Ql^ka
4、释放连接 $mp7IZE|
cn.close(); Lf7iOW9U3
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection ,]20I _
PP$Ig2Q
可滚动、更新的记录集 1AA(qE
1、创建可滚动、更新的Statement Yo(8mtYU
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); CbK7="48
该Statement取得的ResultSet就是可滚动的 qdUlT*fw
2、创建PreparedStatement时指定参数 F'|,(P
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); ^3AJYu
ResultSet.absolute(9000); -/7[_,
批量更新 Tcr&{S&o
1、Statement j+Wgjf
Statement sm = cn.createStatement(); (?q]E$
@
sm.addBatch(sql1); 5C{X$7u
sm.addBatch(sql2); 0.&gm@A~c$
... yTbBYx9Bi
sm.executeBatch() RwT.B+Onuy
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 aLq=%fsV)
2、PreparedStatement ZYu^Q6b3
PreparedStatement ps = cn.preparedStatement(sql); 0~BQ8O=+mn
{ zB 7wGl9
ps.setXXX(1,xxx); :tR%y"
... E39:}_IV
ps.addBatch(); >-+MWu=
} lL%7lO
ps.executeBatch(); G{ F>=z"(l
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 r_
r+&4n
2c9@n9Vx3a
事务的处理 {zmo7~=
1、关闭Connection的自动提交 ed*=p
l3.
cn.setAutoCommit(false); =ngu*#?c4
2、执行一系列sql语句 ^<sX^V+{
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close 2ZLK`^S
Statement sm ; x7{,4js
sm = cn.createStatement(insert into user...); eYR/kZ%<
sm.executeUpdate(); }L:LcM
sm.close(); nLT]'B]$+
sm = cn.createStatement("insert into corp...); LhV4 ^\+
sm.executeUpdate(); x-Xb4?{
sm.close(); yf_<o
3、提交 '_(oa<g
cn.commit(); QZQ@C# PR;
4、如果发生异常,那么回滚 ;|9VPv/
cn.rollback();