java 数据库基本操作 *`]#ntz9
1、java数据库操作基本流程 a>H8,a
2、几个常用的重要技巧: 5jNDr`pnu
可滚动、更新的记录集 /gH[|d
批量更新 '}5Yc,
事务处理 [`n)2}
k
XG!s+ShFV
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 e)M)q!nG
1、取得数据库连接 O3JBS^;V2
1)用DriverManager取数据库连接 >OxSrc@A
例子 q?##S'
String className,url,uid,pwd; ;h~v,h
className = "oracle.jdbc.driver.OracleDriver"; ^]zC~LfG
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; ']&rPvkL
uid = "system"; Cs2F/M'
pwd = "manager"; dbsD\\,2%N
Class.forName(className); S_ER^Pkg
Connection cn = DriverManager.getConnection(url,uid,pwd); #S|DoeFs
2)用jndi(java的命名和目录服务)方式 o%SD\zk
例子 N|-'Fu
String jndi = "jdbc/db"; ^[g7B"`K5
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); #d* )W3e2{
DataSource ds = (DataSource) ctx.lookup(jndi); H&*KpOL
Connection cn = ds.getConnection(); qP5'&!s&!
多用于jsp中 BG9.h!
2、执行sql语句 h0z>dLA#2
1)用Statement来执行sql语句 JwNB)e
D
String sql; WV&grG|
Statement sm = cn.createStatement(); V48o+ O
sm.executeQuery(sql); // 执行数据查询语句(select) PRi1 `%d
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); Dt~ |)L+
2)用PreparedStatement来执行sql语句 /%{Qf
String sql; "8l&m6`U-
sql = "insert into user (id,name) values (?,?)"; b?]Lx.l-
PreparedStatement ps = cn.prepareStatement(sql); /H'F4->
ps.setInt(1,xxx); [bh8Nj\E
ps.setString(2,xxx); /^\UB
fE
... Qq{>]5<
ResultSet rs = ps.executeQuery(); // 查询 I&JjyR
int c = ps.executeUpdate(); // 更新 SL$ bV2T
H"vkp~u]I
3、处理执行结果 :vXlni7N[M
查询语句,返回记录集ResultSet cCBYM
更新语句,返回数字,表示该更新影响的记录数 G$oi>zt3
ResultSet的方法 kn9e7OO##
1、next(),将游标往后移动一行,如果成功返回true;否则返回false Yc3Rq4I'G
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 Wz+7CRpeP
x='T`*HD
4、释放连接 vrX@T?>
cn.close(); +i@{h9"6g
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection I-L:;~.
0nsj ihw
可滚动、更新的记录集 iOrpr,@
1、创建可滚动、更新的Statement `Kb"`}`_vm
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); lN~V1(1B
该Statement取得的ResultSet就是可滚动的
3PUyua'
2、创建PreparedStatement时指定参数 $d\>^Q
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); 2H9;4>ss
ResultSet.absolute(9000); 4N[KmNi<
批量更新 i(mQbWpN
1、Statement 4apaUP=Jp
Statement sm = cn.createStatement(); Ka/ *Z4"
sm.addBatch(sql1); GyQ9we~
sm.addBatch(sql2); ~5]%+G
... <,+nS%a
sm.executeBatch() "pMx(
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 hF^y4v|5
2、PreparedStatement tl"?AQcBR
PreparedStatement ps = cn.preparedStatement(sql); yOswqhz
{ yFY:D2
ps.setXXX(1,xxx); l|j}Ggen
... C3:CuoE X
ps.addBatch(); EWC{896,
} U["-`:>jfp
ps.executeBatch(); DkJ "#8Yl=
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 B&rw R/d
YT~h1<se
事务的处理 $!v:@vNMs
1、关闭Connection的自动提交 \(`8ng]vs
cn.setAutoCommit(false); L+D 9ZE]
2、执行一系列sql语句 b <z)4
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close @/W~lJ!e
Statement sm ; >m+Fm=
sm = cn.createStatement(insert into user...); /C
sm.executeUpdate(); `'G1"CX
sm.close(); !]C=5~BBI
sm = cn.createStatement("insert into corp...); 8)bqN$*h
sm.executeUpdate(); g T{WH67u
sm.close(); W)jtTC7
3、提交 <^da-b>C
cn.commit(); \'CA:9V}
4、如果发生异常,那么回滚 uD4j.%
cn.rollback();