java 数据库基本操作 --FvE|I
1、java数据库操作基本流程 *N7\d9y
2、几个常用的重要技巧: "xWC49
可滚动、更新的记录集 61wiXX"N
批量更新 }+z}vb
事务处理 fYwumx`J
m|!sY[!
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 ;kY=}=9
1、取得数据库连接 TWy1)30x
1)用DriverManager取数据库连接 fy-(B;
例子 epQ7@9,Q
String className,url,uid,pwd; qFay]V(O|
className = "oracle.jdbc.driver.OracleDriver"; X]N8'Yt
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; h<?Vzl
uid = "system"; kHJjdgV
pwd = "manager"; #p^D([k
\
Class.forName(className); uy$o%NL-7
Connection cn = DriverManager.getConnection(url,uid,pwd); PWTAy\
2)用jndi(java的命名和目录服务)方式 #N*~Q
例子 nv|&|6?`oK
String jndi = "jdbc/db"; o;t{YfK
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); [=Xvp z
DataSource ds = (DataSource) ctx.lookup(jndi); t ,0~5>5
Connection cn = ds.getConnection(); g%K3ah
v
多用于jsp中 1_A< nt?'R
2、执行sql语句 ;lGjj9we>
1)用Statement来执行sql语句 c Mq|`CM
String sql; iKu5K0x{>I
Statement sm = cn.createStatement(); |KuH2,n0
sm.executeQuery(sql); // 执行数据查询语句(select) L;Nm"[`
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); \hg12],#:@
2)用PreparedStatement来执行sql语句 xk#/J]j
String sql; !aLL|}S
sql = "insert into user (id,name) values (?,?)"; T7[ItLZ
PreparedStatement ps = cn.prepareStatement(sql); ~#wq sm
ps.setInt(1,xxx); (|W@p\Q
ps.setString(2,xxx); ;#AV~Y-
s
... HH^eEh4g
ResultSet rs = ps.executeQuery(); // 查询 xand%XNv
int c = ps.executeUpdate(); // 更新 J5429Soo
}nkX-PG9
3、处理执行结果 )H)HR`
查询语句,返回记录集ResultSet ^27r-0|l^
更新语句,返回数字,表示该更新影响的记录数 ^hU7QxW
ResultSet的方法 RK|C* TCnl
1、next(),将游标往后移动一行,如果成功返回true;否则返回false m!g
f!
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 lOql(ZH`w
b?y3m +V`
4、释放连接 +g(QF
cn.close(); >xT8[
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection E#J+.&2
-|g~--@Q
可滚动、更新的记录集 8!1vsEqv
1、创建可滚动、更新的Statement 4jvgyi9
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); 8dP^zjPj
该Statement取得的ResultSet就是可滚动的 `C,47 9~J
2、创建PreparedStatement时指定参数 #5F\zeo@F?
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); $cnIsyKWY
ResultSet.absolute(9000); $Die~rPU
批量更新 O.}{s;
1、Statement d&F8nBIM5
Statement sm = cn.createStatement(); ~i(X{^,3
sm.addBatch(sql1); k5(@n>p
sm.addBatch(sql2); TC'tui
... Po% V%~
sm.executeBatch() _L9`bzZj
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 Ue!
&Vm
2、PreparedStatement
t;{/Q&C
PreparedStatement ps = cn.preparedStatement(sql); 9|fg\C
{ .^ soX}
ps.setXXX(1,xxx); 5EM(3eY ^q
... s~,Y po?
ps.addBatch(); Nw8lg*t"
} =j6f/8
ps.executeBatch(); F8f@^LVM/
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 @a+1Ri`)
L'.7V ~b{
事务的处理 I6~.sTl
1、关闭Connection的自动提交 =
oQ-I
cn.setAutoCommit(false); J&wrBVv1uk
2、执行一系列sql语句 0KE+RzrB
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close USv: +
.
Statement sm ; Y$shn]~
sm = cn.createStatement(insert into user...); V |)3l7IC<
sm.executeUpdate(); (i1]+.
sm.close(); tRFj<yuaq
sm = cn.createStatement("insert into corp...); jUYb8:B
sm.executeUpdate(); #2s$dI
sm.close(); }[k~JXt
3、提交 voEg[Gg4%I
cn.commit(); ng"R[/)In
4、如果发生异常,那么回滚 Jc95Ki1X
cn.rollback();