java 数据库基本操作 2X=*;r"{J
1、java数据库操作基本流程 U?ZxQj66}
2、几个常用的重要技巧: ;*e$k7}F
可滚动、更新的记录集 \ X;)Kt"
批量更新 gR k+KGKn<
事务处理 ~93+Oxg
@FuX^Q.[
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 HE3x0H}o>
1、取得数据库连接 Y^,G}
&p
1)用DriverManager取数据库连接 QkY;O<Y_
例子 "C]_pWk
String className,url,uid,pwd; \05 n$.
className = "oracle.jdbc.driver.OracleDriver"; PL*kjrLu7
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; (M,*R
v
uid = "system"; Fpntd IU
pwd = "manager"; `wLMJ,@f.
Class.forName(className); C?PgC~y)
Connection cn = DriverManager.getConnection(url,uid,pwd); /Y*6mQ:
2)用jndi(java的命名和目录服务)方式 2@pEuB3$?!
例子 v ce1'aW
String jndi = "jdbc/db"; 9'h4QF+Y
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); 1.q
a//'RW
DataSource ds = (DataSource) ctx.lookup(jndi); M!]g36h[
Connection cn = ds.getConnection(); hgF4PdO1e
多用于jsp中 hkR Jqta)
2、执行sql语句 yA-UXKT
1)用Statement来执行sql语句 `xu/|})KI
String sql; RQd5Q.
Statement sm = cn.createStatement(); OeY+Yt0
sm.executeQuery(sql); // 执行数据查询语句(select) m-}6DN
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); Z$ Mc{
2)用PreparedStatement来执行sql语句 7a'@NgiGg
String sql; W$?Bsz)
sql = "insert into user (id,name) values (?,?)"; FLOSdMYdw
PreparedStatement ps = cn.prepareStatement(sql); v/}hy$7
ps.setInt(1,xxx); k[;(@e@c
ps.setString(2,xxx); |%7OI#t^
... DX@*lM
ResultSet rs = ps.executeQuery(); // 查询 "(SZ;y
int c = ps.executeUpdate(); // 更新 [}=/?(5
t[?O*>
3、处理执行结果 St~a/Lq6
查询语句,返回记录集ResultSet }TAHVcX*p
更新语句,返回数字,表示该更新影响的记录数 YNWAef4
ResultSet的方法 +#0,2wR#
1、next(),将游标往后移动一行,如果成功返回true;否则返回false [[9XqD]
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 RF.8zea{O`
tz"zQC$
4、释放连接 <bxp/#6D
cn.close(); L#NW<T
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection dEM=U;
U4$CkTe2Y
可滚动、更新的记录集 qECta'b&
1、创建可滚动、更新的Statement NHq*&xy
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); K=X13As_
该Statement取得的ResultSet就是可滚动的 4GTB82V$
2、创建PreparedStatement时指定参数 E0Jk=cq
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); dGBVkb4]T
ResultSet.absolute(9000); l:rT{l=8*
批量更新 p(]o#$ 6[
1、Statement h2]gA_T`
Statement sm = cn.createStatement(); $+.!(Js"K
sm.addBatch(sql1); Ik74%x7G`
sm.addBatch(sql2); vx8-~Oq{|;
... .~Z@y#
sm.executeBatch() V57tn6>b
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 rq>OmMQ67
2、PreparedStatement #GT4/Ej}W
PreparedStatement ps = cn.preparedStatement(sql); 1P+Te,I
{ Swg%[r=p=
ps.setXXX(1,xxx); F/I`EV
... ^-i<TJ
ps.addBatch(); 8h| 9;%
} P1f@?R&t+
ps.executeBatch(); %1oG<s
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 Us*"g{PQ
($ l
t@j
事务的处理 QL4BD93v
1、关闭Connection的自动提交 *n h.&Mv|
cn.setAutoCommit(false); rF8nz:8
2、执行一系列sql语句 d*{NAq'9X
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close 3\jcq@N
Statement sm ; 4]$$ar)
sm = cn.createStatement(insert into user...); /Sag_[i
sm.executeUpdate(); &=d0'3k>
sm.close(); \P` mV9P
sm = cn.createStatement("insert into corp...); CnA0^JX
sm.executeUpdate(); a9 CK4Kg
sm.close(); 8QYM/yAM
3、提交 GE{u2<%@
cn.commit(); ') -Rv]xe
4、如果发生异常,那么回滚 uNn]hl|x
cn.rollback();