java 数据库基本操作 mZS
>O_E
1、java数据库操作基本流程 mI-]/:
2、几个常用的重要技巧: 0WW2i{7`U
可滚动、更新的记录集 z,[Hli*0
批量更新 ICx#{q@f,
事务处理 QC
OM_$ y
{tuYs:
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 .Ni\\
1、取得数据库连接 S"bg9o
1)用DriverManager取数据库连接 NdA[C|_8}f
例子 ~F|+o}a`
String className,url,uid,pwd; y1eWpPJa
className = "oracle.jdbc.driver.OracleDriver"; 3</_c1~
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; [2!w_Iw'
uid = "system"; u"cV%(#
pwd = "manager"; *e TqVG.
Class.forName(className); X"|['t
Connection cn = DriverManager.getConnection(url,uid,pwd); *k( XW_>
2)用jndi(java的命名和目录服务)方式 y*jp79G
例子 jjB~G^n
String jndi = "jdbc/db"; m<T%Rb4?@
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); O~#!l"0 L+
DataSource ds = (DataSource) ctx.lookup(jndi); ,F8 Yn5h
Connection cn = ds.getConnection(); gZ3u=uME
多用于jsp中 Xv5wJlc!d
2、执行sql语句 b7?uq9
1)用Statement来执行sql语句 r"3=44St
String sql; Pe_W;q.
Statement sm = cn.createStatement(); wtQ++l%{G
sm.executeQuery(sql); // 执行数据查询语句(select) \R9(x]nZ%
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); z1 |TC
2)用PreparedStatement来执行sql语句 v!-/&}W)1
String sql; 36&e.3/#
sql = "insert into user (id,name) values (?,?)"; [[Ls_ZL!=
PreparedStatement ps = cn.prepareStatement(sql); F3[T.sf
ps.setInt(1,xxx); ^+>laOzC`8
ps.setString(2,xxx); T\6dm/5
... 2+N]PW\V
ResultSet rs = ps.executeQuery(); // 查询 KEo,m
int c = ps.executeUpdate(); // 更新 T"}5}6rSG
XSwl Tg
3、处理执行结果 r4b 6 c
查询语句,返回记录集ResultSet 7?!d^$B
更新语句,返回数字,表示该更新影响的记录数 ed{ -/l~j
ResultSet的方法 z [}v{
1、next(),将游标往后移动一行,如果成功返回true;否则返回false .]Y$o^mf
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 ;C9_?u~#
4<w.8rR:A
4、释放连接 JQ_sUYh~3
cn.close(); k<nZ+! M
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection ,GhS[VJjR
,h m\
可滚动、更新的记录集 X6w6%fzOH>
1、创建可滚动、更新的Statement `iFmrC<
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); <y('hI'
该Statement取得的ResultSet就是可滚动的 Wq D4YGN
2、创建PreparedStatement时指定参数 2G& a{
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); 9rA0lqr]5
ResultSet.absolute(9000); "+R+6<