java 数据库基本操作 W$Aypy
1、java数据库操作基本流程 :n
x;~f
2、几个常用的重要技巧: 7FP"]\x
可滚动、更新的记录集 ~$Z_#,|i?
批量更新 o
i~,}E_
事务处理 "DJ%Yo
kQ)2DCbdn
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 ^4saB+qm
1、取得数据库连接 ZQ[s:
1)用DriverManager取数据库连接 xrJ0
例子 ~<osL
String className,url,uid,pwd; %u]>K(tU
className = "oracle.jdbc.driver.OracleDriver"; !W=2ZlzS
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; vha@YPC=
uid = "system"; A{')
pwd = "manager"; I+Fr#1
Class.forName(className); \}Pr!tk!
Connection cn = DriverManager.getConnection(url,uid,pwd); )9!ZkZbv_m
2)用jndi(java的命名和目录服务)方式 a$6pA@7}
例子 E
6!V0D
String jndi = "jdbc/db"; F#efs6{
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); _g"su#
DataSource ds = (DataSource) ctx.lookup(jndi); b|`
Connection cn = ds.getConnection(); uQWd`7
多用于jsp中 ^^)\|kW?
2、执行sql语句 gti=GmL(L
1)用Statement来执行sql语句 $ g#d1u0q
String sql; ZPY84)A_}
Statement sm = cn.createStatement(); e9B$"_ &2
sm.executeQuery(sql); // 执行数据查询语句(select) !|Y&h0e
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); ?
5hwz
2)用PreparedStatement来执行sql语句 bHHR^*B
String sql; c;R.rV<
sql = "insert into user (id,name) values (?,?)"; 8EI&}I
PreparedStatement ps = cn.prepareStatement(sql); Z,b^f
Vw
ps.setInt(1,xxx); a&R,jq
ps.setString(2,xxx); 1+Y;
"tT
... .fY$$aD$4
ResultSet rs = ps.executeQuery(); // 查询 s|"4!{It
int c = ps.executeUpdate(); // 更新 $I/RN
)/tdiRpn
3、处理执行结果 061 f
查询语句,返回记录集ResultSet Ob-k`@_|
更新语句,返回数字,表示该更新影响的记录数 )v.\4Q4
ResultSet的方法 ]JI
A\|b6
1、next(),将游标往后移动一行,如果成功返回true;否则返回false 0j{KZy
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 a3(f\MMxE
y? 65*lUl
4、释放连接 /p@0Q[E
cn.close(); zPb"6%1B
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection #kQLHi3##
z.kBQ{P
可滚动、更新的记录集 %M05& <
1、创建可滚动、更新的Statement {|@N~c+
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); Wy$Q!R=i
该Statement取得的ResultSet就是可滚动的 \G1(r=fU
2、创建PreparedStatement时指定参数 /M_kJe,%
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); DRi/<
ResultSet.absolute(9000); nL!nzA
批量更新 faI4`.i
1、Statement w~*"mZaG
Statement sm = cn.createStatement(); TUVqQ\oF:
sm.addBatch(sql1); s-xby~
sm.addBatch(sql2); 9}Zi_xK&|e
... E}=F
sm.executeBatch() ~3m}
EL
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 'MIM_m)H
2、PreparedStatement <4Cy U
j
PreparedStatement ps = cn.preparedStatement(sql); {pB9T3ry]
{ v#+tu,)V;
ps.setXXX(1,xxx); 2VS#=i(B^
... *|:]("i
ps.addBatch(); v_@!u`
} k\M">K0E
ps.executeBatch(); BH=CoD.
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 z3-AYQ.H
^kpu9H
事务的处理 GD .>u
1、关闭Connection的自动提交 93#wU})
cn.setAutoCommit(false); iD9hqiX&
2、执行一系列sql语句 MMUw+jM4
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close #Y<b'7yJ
Statement sm ; b~FmX
sm = cn.createStatement(insert into user...); =p';y&
sm.executeUpdate(); 5($
'@u
sm.close(); N
DV_/BI
sm = cn.createStatement("insert into corp...); S>p>$m,
Q
sm.executeUpdate(); DnPV
Tp(>
sm.close(); uc;QSVWGy8
3、提交 9Uh nr]J.
cn.commit(); Y~M H
4、如果发生异常,那么回滚 ]7{-HuQ8>}
cn.rollback();