java 数据库基本操作 @k'V`ZQF
1、java数据库操作基本流程 Q^05n$ tI
2、几个常用的重要技巧: Ux= B*m1@{
可滚动、更新的记录集 0mmHN`<
批量更新 gnxD'1_
事务处理 r[GH#vF;7
XsFzSm
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 WT1y7+_g(d
1、取得数据库连接 T
7qHw!)
1)用DriverManager取数据库连接 asmu<
例子 N cGFPi(Z
String className,url,uid,pwd; M:& %c3
className = "oracle.jdbc.driver.OracleDriver"; 4ZR2U3jd1
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; ,Sy&?t}`
uid = "system"; C6@*l~j
pwd = "manager"; ^mC,Z+!
Class.forName(className); tc\ZYCFr
Connection cn = DriverManager.getConnection(url,uid,pwd); `cN8AcRHP
2)用jndi(java的命名和目录服务)方式 vv^y
V"0Y
例子 -F3~X R
String jndi = "jdbc/db"; 5gC>j(
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); 5e0d;Rd
DataSource ds = (DataSource) ctx.lookup(jndi); ),j6tq[
Connection cn = ds.getConnection(); bF+j%=
多用于jsp中 tw\1&*:
2、执行sql语句 F`{O
1)用Statement来执行sql语句 0,.|-OZ
String sql; M_r[wYt!
Statement sm = cn.createStatement(); K3,PmI&W
sm.executeQuery(sql); // 执行数据查询语句(select) oJ"D5d,
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); |m@>AbR5dk
2)用PreparedStatement来执行sql语句 +StsSZ
String sql; 8?: 2<
sql = "insert into user (id,name) values (?,?)"; +|5 O b
PreparedStatement ps = cn.prepareStatement(sql); .4$F~!aj9
ps.setInt(1,xxx); [*0M$4
ps.setString(2,xxx); '#,C5*`
... bs16G3-p
ResultSet rs = ps.executeQuery(); // 查询 'Yc^9;C(
int c = ps.executeUpdate(); // 更新 hH%fWB2(
fZ;}_wR-H
3、处理执行结果 >dD$GD{
查询语句,返回记录集ResultSet n'JS-
更新语句,返回数字,表示该更新影响的记录数 FS!)KxC/-
ResultSet的方法 gm!sLZ!X
1、next(),将游标往后移动一行,如果成功返回true;否则返回false 8.I3%u
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 /_Ku:?{
}Ujgd2(U
4、释放连接 ('\sUZ+5
cn.close(); |R!ozlL{}
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection k9:|CEP
#)[.Xz:U
可滚动、更新的记录集 y*US^HJOZ
1、创建可滚动、更新的Statement , `EOJ"|
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); C-h?#/#?y
该Statement取得的ResultSet就是可滚动的 a1%}Ee
2、创建PreparedStatement时指定参数 8IBr#+0
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); ib!TXWq
ResultSet.absolute(9000); A:yql`&s
批量更新 Qc PU{#6
1、Statement NPM2qL9&J
Statement sm = cn.createStatement(); ,\aLv
sm.addBatch(sql1); eQn[
sm.addBatch(sql2); ?cKTeGrS
... 0)
F\aJ4Y
sm.executeBatch() %f1IV(3Qc
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 Km,o+9?1gF
2、PreparedStatement R osU~OK
PreparedStatement ps = cn.preparedStatement(sql); O/d]2<V
{ suGd &eP|
ps.setXXX(1,xxx);
_Rkvg-
... dn Sb}J
ps.addBatch(); f\.y z[
} cx&\oP
ps.executeBatch(); n4}e!
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 twbxi{8e.
z5Tsu1c
事务的处理 t+]1D@h v
1、关闭Connection的自动提交 H=g%>W%3
cn.setAutoCommit(false); `<|<1,
2、执行一系列sql语句 |>m'szca4
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close 8c_X`0jy
Statement sm ; i?uX'apk
sm = cn.createStatement(insert into user...); uGqeT#dP
sm.executeUpdate(); /{R.
sm.close(); i1m>|[@k
sm = cn.createStatement("insert into corp...); F[!%,-*
sm.executeUpdate(); tm2lxt
sm.close(); ,Oy$q~.
3、提交 EBz4k)@m
cn.commit(); Z2H bAI8
4、如果发生异常,那么回滚 U,61 3G
cn.rollback();