java 数据库基本操作 6N4~~O
1、java数据库操作基本流程 gJXaPJA{
2、几个常用的重要技巧: }OUt sh ]y
可滚动、更新的记录集 AKC`TA*E
批量更新 \~W'v3:W
事务处理 8=l%5r^cq
cr3^6HB
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 @5FQX
1、取得数据库连接 u_enqC3
1)用DriverManager取数据库连接 b;n[mk
例子 J zl6eo[;
String className,url,uid,pwd; ,F|f. 7;
className = "oracle.jdbc.driver.OracleDriver"; p2eGm-Erq
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; }tz7b#
uid = "system"; [WmM6UEVS
pwd = "manager"; ueudRb
Class.forName(className); h0$iOE
Connection cn = DriverManager.getConnection(url,uid,pwd); &8H'eAA
2)用jndi(java的命名和目录服务)方式 b=vkiO`2
例子 t_^4`dW`
String jndi = "jdbc/db"; C]6O!Pb0
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); )e{aN+
DataSource ds = (DataSource) ctx.lookup(jndi); d6O[ @CyP
Connection cn = ds.getConnection(); 5O%{{J
多用于jsp中 (>Em^(&
2、执行sql语句 I,tud!p`
1)用Statement来执行sql语句 {FkF
String sql; &Jj<h: *
Statement sm = cn.createStatement(); @dKTx#gZ
sm.executeQuery(sql); // 执行数据查询语句(select) 7I}uZ/N
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); Y]>t[Lo%
2)用PreparedStatement来执行sql语句 eFgA 8kY)
String sql; 7dWS
sql = "insert into user (id,name) values (?,?)"; ,bi^P>X
PreparedStatement ps = cn.prepareStatement(sql);
P0@,fd<
ps.setInt(1,xxx); TbU#96"~.
ps.setString(2,xxx); 4 KiY6)
... (=0.in Z
ResultSet rs = ps.executeQuery(); // 查询 ~$'awY
int c = ps.executeUpdate(); // 更新 ;l+Leex
# d
3、处理执行结果 Vr}'.\$
查询语句,返回记录集ResultSet l#o
~W`
更新语句,返回数字,表示该更新影响的记录数 aN?zmkPpov
ResultSet的方法 /:
"1Z]@
1、next(),将游标往后移动一行,如果成功返回true;否则返回false <)9y{J}s:
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 CJ}%W#
4Z*/WsCv
4、释放连接 )7F/O3Tq
cn.close(); 4RO}<$Nx}
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection m0wDX*Qn
th_oJcS
可滚动、更新的记录集 sC'`~}C
1、创建可滚动、更新的Statement G{}VPcrbC
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); @JMiO^
该Statement取得的ResultSet就是可滚动的 C+$#y2"z#n
2、创建PreparedStatement时指定参数 $4LzcwG
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); {)XTk&"
ResultSet.absolute(9000); 79gT+~z
批量更新 N8jIMb'<
1、Statement <~)P7~$d?p
Statement sm = cn.createStatement(); k[xSbs'D
sm.addBatch(sql1); HPl<%%TI
sm.addBatch(sql2); pBHRa?Y5
... x5Bk/e'
sm.executeBatch() SUiOJ[5,
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 >:-$+I
2、PreparedStatement (`^1Y3&2
PreparedStatement ps = cn.preparedStatement(sql); 04ui`-c(
{ X?O[r3<
ps.setXXX(1,xxx); @d'j zs
... H_a[)DT
ps.addBatch(); zhQJy?>'m
} 7!1S)dup
ps.executeBatch(); 3]Ct6
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 (PLUFT
m
O_af
事务的处理 cuX)8+
1、关闭Connection的自动提交 !$JT e
cn.setAutoCommit(false); C%u28|
2、执行一系列sql语句 KlEpzJ98
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close 7CysfBF0g
Statement sm ; :WEDAFq0
sm = cn.createStatement(insert into user...); ES[G
sm.executeUpdate(); f*Hr^b}`8
sm.close(); z{
dEC %
sm = cn.createStatement("insert into corp...); &C}*w2]0S
sm.executeUpdate(); =_CzH(=f#
sm.close(); "oyo#-5z
3、提交 }BEB1Q}L
cn.commit(); w;M#c
Y
4、如果发生异常,那么回滚 81F9uM0
cn.rollback();