java 数据库基本操作 sA2-3V<t8
1、java数据库操作基本流程 &,&+p0CSI!
2、几个常用的重要技巧: N"70P/
可滚动、更新的记录集
!VGG2N8
批量更新 1/}H
0\9'
事务处理 }+@9[Q
L
gm9*z.S\'
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 d[a(uWEl
1、取得数据库连接 kXz~ez 7
1)用DriverManager取数据库连接 %qc_kQ5%
例子 i~';1
.g
String className,url,uid,pwd; T\l`Y-vu
className = "oracle.jdbc.driver.OracleDriver"; m}"Hm(,6
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; *9'3 `^l
uid = "system"; 0S{23L4C
pwd = "manager"; Hyb(.hlZh
Class.forName(className); QEyL/#Q
Connection cn = DriverManager.getConnection(url,uid,pwd); }Ng P`m
2)用jndi(java的命名和目录服务)方式 zgb$@JC
例子 N>I6f
String jndi = "jdbc/db"; 7+HK_wNi
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); SQN?[v
DataSource ds = (DataSource) ctx.lookup(jndi); @v)Z>xv
Connection cn = ds.getConnection(); ?ko#N?hgI
多用于jsp中 xM jn=\}
2、执行sql语句 Ta?J;&<u]/
1)用Statement来执行sql语句 NEq_!!/sF
String sql; tguB@,O
Statement sm = cn.createStatement(); h:4(Gm;
sm.executeQuery(sql); // 执行数据查询语句(select) .QvD603%5
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); <C`bf$ak
2)用PreparedStatement来执行sql语句 d/d)MoaJ*t
String sql; 0*{(R#
sql = "insert into user (id,name) values (?,?)"; !l[;,l
PreparedStatement ps = cn.prepareStatement(sql); D3Q+K
ps.setInt(1,xxx); io#}z4"'qY
ps.setString(2,xxx); !Tnjha*
... |
eBwcC#^
ResultSet rs = ps.executeQuery(); // 查询 o}AXp@cqi
int c = ps.executeUpdate(); // 更新 ^'X
I%fEf
'kd}vq#|
3、处理执行结果 a#p+.)Wm
查询语句,返回记录集ResultSet e;.,x 5+
更新语句,返回数字,表示该更新影响的记录数 _(m72o0g>>
ResultSet的方法 j)J |'b|
1、next(),将游标往后移动一行,如果成功返回true;否则返回false qTuR[(
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 kvbZx{s
w.m8SvS&b
4、释放连接 ^Om}9rXw1
cn.close(); -E7mt`:d
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection R~g|w4a@sC
KXt8IMP_"y
可滚动、更新的记录集 Myc-lCE
1、创建可滚动、更新的Statement t&U9Z$LS
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); Jm4uj&}3
该Statement取得的ResultSet就是可滚动的 WDc[+Xyw
2、创建PreparedStatement时指定参数 Y:\msq1xp
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); LW1 4 'A}
ResultSet.absolute(9000); s<