java 数据库基本操作 Svl;Ul
1、java数据库操作基本流程 m<liPl
uv
2、几个常用的重要技巧: ][TA7pDPV
可滚动、更新的记录集 =v:}{~M^$
批量更新 2K
VX
事务处理 o^8Z cN>
vBLs88
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接
/Y#Q<=X
1、取得数据库连接 `37%|e 3bQ
1)用DriverManager取数据库连接 B{hV|2
例子 4o69t
String className,url,uid,pwd; ]]^r)&pox
className = "oracle.jdbc.driver.OracleDriver"; R}E$SmFg
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; ]]eI80u[
uid = "system"; |QHIB?C?`
pwd = "manager"; Bag_0.H&m
Class.forName(className); Is[n7Q
Connection cn = DriverManager.getConnection(url,uid,pwd); {TVQ]G%'b
2)用jndi(java的命名和目录服务)方式 Memb`3
例子 &WJ;s*
String jndi = "jdbc/db"; "~:P-]`G
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); uGU-MC*
DataSource ds = (DataSource) ctx.lookup(jndi); >v'@p
Connection cn = ds.getConnection(); j^)=<+Q;=
多用于jsp中 *bl|[(pP
2、执行sql语句 6c[Slq!KA
1)用Statement来执行sql语句 +k{l]-)1
String sql; Q79WGW
Statement sm = cn.createStatement(); 8JojKH
sm.executeQuery(sql); // 执行数据查询语句(select) 9l<}`/@}W
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); k!0vpps
2)用PreparedStatement来执行sql语句 E|"QYsi.Ck
String sql; 9 Eqv^0u
sql = "insert into user (id,name) values (?,?)"; cyH=LjgJf
PreparedStatement ps = cn.prepareStatement(sql); c1M *w9o
ps.setInt(1,xxx); ZYLPk<<
ps.setString(2,xxx); AvZOR
... %zYTTPLZ
ResultSet rs = ps.executeQuery(); // 查询 xFA+ZjBC
int c = ps.executeUpdate(); // 更新 Pah*,
/:ju/~R}
3、处理执行结果 f64}#E|w
查询语句,返回记录集ResultSet 4K0Fc^-
更新语句,返回数字,表示该更新影响的记录数 orZwm9#].
ResultSet的方法 08_<G`r
1、next(),将游标往后移动一行,如果成功返回true;否则返回false X- P%^mK
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 R@
MXwP
'byao03
4、释放连接 0
} |21YED
cn.close(); (YY!e2
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection
MZ%S3'
%4x,^ K]
可滚动、更新的记录集 '-V[tyE
1、创建可滚动、更新的Statement l9+)h}
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); X&gXhr#dL\
该Statement取得的ResultSet就是可滚动的 xA>3]<O
2、创建PreparedStatement时指定参数 ;%mdSaf
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); }*|aVBvU
ResultSet.absolute(9000); ZK`x(h{p)
批量更新 L.x`Jpq(3
1、Statement wpf
Statement sm = cn.createStatement(); `,s0^?_
sm.addBatch(sql1); Mi<}q@]e
sm.addBatch(sql2); T~naAP
... ,!bcm
sm.executeBatch() o@qI!?p&
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 `^:
v+!
2、PreparedStatement F>
b<t.yV
PreparedStatement ps = cn.preparedStatement(sql); g+QNIM>
{ SD .c9
ps.setXXX(1,xxx); ~EO=;a_
... ge[&og/$
ps.addBatch(); 97n,^t2F\
} <ahcE1h
ps.executeBatch(); @#::C@V]
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 @5\/L6SRfL
fl71{jJ_
事务的处理 N6h.zl&04
1、关闭Connection的自动提交 *lyRy/POB
cn.setAutoCommit(false); y<^hM6S?Z
2、执行一系列sql语句 i)[~]D.EH8
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close S~\u]j^%y
Statement sm ; QuBaG<
sm = cn.createStatement(insert into user...); kYu"`_n}
sm.executeUpdate(); *?!A
sm.close(); 0c]3 ,#
sm = cn.createStatement("insert into corp...); $Hal]
sm.executeUpdate(); 24I~{Qy
sm.close(); cpQhg-LY|
3、提交 18JAca8Zs
cn.commit(); 7Yly^
4、如果发生异常,那么回滚 q&@q/9kz
cn.rollback();