java 数据库基本操作 Q)DEcx-|,
1、java数据库操作基本流程 Lq2Q:w'
2、几个常用的重要技巧: e= IdqkJ%
可滚动、更新的记录集 79v +ze
批量更新 SK}sf9gTv
事务处理 qzUiBwUi@
y2jv84
M
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 _O`p (6
1、取得数据库连接 h0tiWHw
1)用DriverManager取数据库连接 P R%)3
例子 )@NFV*@I
String className,url,uid,pwd; i1vz{Tc
className = "oracle.jdbc.driver.OracleDriver"; d4S4
e
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; V*j l
uid = "system"; fEHFlgN3Ap
pwd = "manager"; &B{zS K$N
Class.forName(className); Qn*l,Z]US
Connection cn = DriverManager.getConnection(url,uid,pwd); -V/y~/]J
2)用jndi(java的命名和目录服务)方式 ^k=<+*9
例子 I2[Z0G@&=
String jndi = "jdbc/db"; <=M5)#
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); Nw*<e ]uD
DataSource ds = (DataSource) ctx.lookup(jndi); W"c\/]aD
Connection cn = ds.getConnection(); 1<r!9x9G
多用于jsp中 V~*Gk! +f
2、执行sql语句 gk%nF
1)用Statement来执行sql语句 dk|LC-]`A
String sql; 72dRp!JU
Statement sm = cn.createStatement(); z
&EDW5I
sm.executeQuery(sql); // 执行数据查询语句(select) &=g3J4$z
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); :#YC_
id
2)用PreparedStatement来执行sql语句 {rc3`<%
String sql; *D?=Ts
sql = "insert into user (id,name) values (?,?)"; .4zzPD$1
PreparedStatement ps = cn.prepareStatement(sql); jJ#D`iog5
ps.setInt(1,xxx); g0B] ;Y>(
ps.setString(2,xxx); s2O()u-
... ip-X r|Bq
ResultSet rs = ps.executeQuery(); // 查询 |a{;<a
int c = ps.executeUpdate(); // 更新 Nny*C`uDF
q\EYsN</;
3、处理执行结果 !mlfG"FE
查询语句,返回记录集ResultSet hVzyvpw
更新语句,返回数字,表示该更新影响的记录数 @_ %RQO_X
ResultSet的方法 cMY}Y
[2c
1、next(),将游标往后移动一行,如果成功返回true;否则返回false rN}pi@
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 &
kC
/~NX<Ye&
4、释放连接 A6z,6v6
cn.close();
d$$5&a
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection q} e#L6cM
{=GmXd%D
可滚动、更新的记录集 !Cr3>tA
1、创建可滚动、更新的Statement
:^)?AO#J
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); aopPv&jY
该Statement取得的ResultSet就是可滚动的 5P!ZGbG
2、创建PreparedStatement时指定参数 +e{ui +
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); fd'kv
ResultSet.absolute(9000); +``vnC
批量更新 rCPIz<
1、Statement T!c|O3m
Statement sm = cn.createStatement(); HMd?`
sm.addBatch(sql1); Nc\DXc-N
sm.addBatch(sql2); *Jsb~wta
... XDPR$u8hM
sm.executeBatch() <x}wy+SG
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 !n-Sh<8
2、PreparedStatement KhR3$|fH<
PreparedStatement ps = cn.preparedStatement(sql); ",/6bs#$
{ 4S26TgY
ps.setXXX(1,xxx); poQ_r<I
... r2RJb6
ps.addBatch(); *:L"#20:R
} Z<X=00,wg
ps.executeBatch(); eK7A8\;e
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 y0xBNhev
~0PzRS^o
事务的处理 >$m<R&
1、关闭Connection的自动提交 !aT:0m$:9c
cn.setAutoCommit(false); kY]"3a
2、执行一系列sql语句 {)qr3-EM#
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close 2y`h'z
Statement sm ; _[6sr7H!
sm = cn.createStatement(insert into user...); 3 yx[*'e$
sm.executeUpdate(); ljbAfd
sm.close(); 1V2]@VQF
sm = cn.createStatement("insert into corp...); |=q~X}DA
sm.executeUpdate(); M(C">L]8
sm.close(); );!ND%
3、提交 .n7@$kq
cn.commit(); s{^B98d+W
4、如果发生异常,那么回滚 tD.#*.7
cn.rollback();