java 数据库基本操作 {43>m)8+
1、java数据库操作基本流程 Xp0F
[>h
2、几个常用的重要技巧: jck}" N
可滚动、更新的记录集 ys 5&PZg*
批量更新 Vz6Qxd{m3
事务处理 a5a($D
Reatdh
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 S[WG$
1、取得数据库连接 Sb~MQ_
1)用DriverManager取数据库连接 #>Zzf
例子 `{qG1
String className,url,uid,pwd; [JF150zr
className = "oracle.jdbc.driver.OracleDriver"; g=I8@m
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; sc,Xw:YO
uid = "system"; o=0]el^A
pwd = "manager"; E[Cb|E
Class.forName(className); |4'Y/re
Connection cn = DriverManager.getConnection(url,uid,pwd); y+7w,m2
2)用jndi(java的命名和目录服务)方式 ~NW32
O)/
例子 zOQ>d|p?X
String jndi = "jdbc/db"; B^g ?=|{
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); q$=#A7H>3)
DataSource ds = (DataSource) ctx.lookup(jndi); (<^ yqH?
Connection cn = ds.getConnection(); w*R$o
多用于jsp中 8By|@LO
2、执行sql语句 L|p
Z$HB
1)用Statement来执行sql语句 Ol!ntNhXm
String sql; VkZ7#
Statement sm = cn.createStatement(); nqLA}u4IM
sm.executeQuery(sql); // 执行数据查询语句(select) qvPtyc^fN
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); M![J2=
2)用PreparedStatement来执行sql语句 BCA&mi3q
String sql; 720D V+o
sql = "insert into user (id,name) values (?,?)"; R?]02Q
PreparedStatement ps = cn.prepareStatement(sql); '3uVkp 6tF
ps.setInt(1,xxx); 8@tV9+u
ps.setString(2,xxx); kh`"WN Nt
... 6i}iAP|0
ResultSet rs = ps.executeQuery(); // 查询 s_mS^`P7
int c = ps.executeUpdate(); // 更新 ~ 0M'7q'
1')%`~
3、处理执行结果 '3g[]M@M
查询语句,返回记录集ResultSet "s{5O>
更新语句,返回数字,表示该更新影响的记录数 <u2 }i<#
ResultSet的方法 NU0g07"
1、next(),将游标往后移动一行,如果成功返回true;否则返回false F]<Xv"
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 H-
$)3"K
>rf'-X4n
4、释放连接 |j,"Pl}il^
cn.close(); =uS9JU^E
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection ~;N^g4s
>Z5gSs0
可滚动、更新的记录集 sIy^m}02
1、创建可滚动、更新的Statement >6?__v]9G
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); ,k;^G><
=
该Statement取得的ResultSet就是可滚动的 1u:<
25
2、创建PreparedStatement时指定参数 =|Y,+/R?
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); }"|K(hq
ResultSet.absolute(9000); K57&yVX
批量更新 qw^uPs7Uw
1、Statement adR)Uq9
Statement sm = cn.createStatement(); ]iUxp+
sm.addBatch(sql1); h5^Z2:#
sm.addBatch(sql2); ,LnII
... OOo3G~2r
sm.executeBatch() k=jk`c{<[
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 "/wyZ
2、PreparedStatement h-[VH%
PreparedStatement ps = cn.preparedStatement(sql); h%uZYsK
{ '!eKTC>
ps.setXXX(1,xxx); .?loO3 m
... >7QvK3S4%
ps.addBatch(); TIQkW,
} )!P)U(*v
ps.executeBatch(); ~
Q. 7VDz
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 UdpF@Q
T9Nb`sbV]
事务的处理 K/|Z$4S
1、关闭Connection的自动提交 x$6^R q>2
cn.setAutoCommit(false); `ojoOB^L
2、执行一系列sql语句 u=`L)
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close \nPEyw,U
Statement sm ; ~Vr.J}]J
sm = cn.createStatement(insert into user...); )p<ExMIxd
sm.executeUpdate(); KbA?7^zo`
sm.close(); n$$SNWgM
sm = cn.createStatement("insert into corp...); d?A
0MKnl
sm.executeUpdate(); 8Djc
c
z
sm.close(); *%%g{
3$
3、提交 VHIOwzC
cn.commit(); w5Y04J
4、如果发生异常,那么回滚 7/I, HxXp!
cn.rollback();