java 数据库基本操作 Qkd<sxL
1、java数据库操作基本流程 fbL\?S,w
2、几个常用的重要技巧: `^FGwx@
可滚动、更新的记录集 bV$)!]V
批量更新 G1"zElug
事务处理 0DmMG
O Vko+X`
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 8rMX9qTO@
1、取得数据库连接 Ar:*oiU
1)用DriverManager取数据库连接 !2'jrJGc
例子 L?Qg#YSd~
String className,url,uid,pwd; (
|PAx(
className = "oracle.jdbc.driver.OracleDriver"; \CXQo4P
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; 3`B6w$z>(
uid = "system"; n ;$5Cq!v=
pwd = "manager"; ?kZTI (
Class.forName(className); "9^j.
Connection cn = DriverManager.getConnection(url,uid,pwd); )6Ny1x+
2)用jndi(java的命名和目录服务)方式 J]G?Rc
例子 2cq I[t@0
String jndi = "jdbc/db"; x7<\]94
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); =}v}my3y"
DataSource ds = (DataSource) ctx.lookup(jndi); sM?MLB\Za
Connection cn = ds.getConnection(); _/s(7y!
多用于jsp中 6C]1Q.f;
2、执行sql语句 u9}1)9
1)用Statement来执行sql语句 B]Y}Hu
String sql; j^;I3_P
Statement sm = cn.createStatement(); lm xr oHE
sm.executeQuery(sql); // 执行数据查询语句(select) -t2+|J*
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); FcRW;e8-
2)用PreparedStatement来执行sql语句 _jNj-)RB_
String sql; v}tag#f5>?
sql = "insert into user (id,name) values (?,?)"; ZP;j9T!
PreparedStatement ps = cn.prepareStatement(sql); _=NwQu\_F
ps.setInt(1,xxx); }p!HT6 tZ
ps.setString(2,xxx); ~d%Pnw|
... FFH_d <q
ResultSet rs = ps.executeQuery(); // 查询 NDs!a
int c = ps.executeUpdate(); // 更新 mXUGe:e8
q@@T]V6
3、处理执行结果 6q]5Es<
查询语句,返回记录集ResultSet &%s8L\?
更新语句,返回数字,表示该更新影响的记录数 '{J&M|<A
ResultSet的方法 <YOLx R
1、next(),将游标往后移动一行,如果成功返回true;否则返回false *r=:y{!Y d
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 Gu'rUo3Do
Pj4/xX
4、释放连接 *+\SyO
cn.close(); h~p>re
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection o4%y>d)
g"?Y+j
可滚动、更新的记录集 >layJt
1、创建可滚动、更新的Statement +> WM[o^I
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); =Uj-^qcE
该Statement取得的ResultSet就是可滚动的 "v`
2、创建PreparedStatement时指定参数 Z7_ zMM
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); ~5 *5
ResultSet.absolute(9000); 3q'&j,,^
批量更新 2A\,-*pc
1、Statement W ]Nv33i
[
Statement sm = cn.createStatement(); .h&
.K
sm.addBatch(sql1); 1XnZy5fEo
sm.addBatch(sql2); e89Xb;;w
... +Wx{:
sm.executeBatch() u6_@.a}
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 ~-dV^SO
2、PreparedStatement &3$z4df
PreparedStatement ps = cn.preparedStatement(sql); >zhO7,=,
{ }t;(VynV)
ps.setXXX(1,xxx); V0%V5>
... wAz&"rS
ps.addBatch(); qR8u$2}NY
} L}FOjrN
ps.executeBatch(); HS.^y
x
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 >TP7 }u|
CXO2N1~(J
事务的处理 13+<Q \
1、关闭Connection的自动提交 `"@g8PWe
cn.setAutoCommit(false); }Y*VAnY6;
2、执行一系列sql语句 u_'!_T L
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close qpsvi.S
Statement sm ; ph_4q@
sm = cn.createStatement(insert into user...); <TE%Prd}`
sm.executeUpdate(); Pf_S[
sm
sm.close(); E-{^E. w1
sm = cn.createStatement("insert into corp...); Y=
]dvc
sm.executeUpdate(); GHHav12][
sm.close(); !Yw3 d
3、提交 TD9;kN1`
cn.commit(); Xu>r~^w=S
4、如果发生异常,那么回滚 MzP7Py
8.
cn.rollback();