java 数据库基本操作 &Xl_sDvt
1、java数据库操作基本流程 3U9+l0mBa
2、几个常用的重要技巧: { ck
可滚动、更新的记录集 L
yA(.
批量更新 Za:BJ:
事务处理 4na4Jsq{
#o"HD6e
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 TJw.e/
1、取得数据库连接 Pu%>j'A
1)用DriverManager取数据库连接 uDE91.pUkr
例子 t~<-4N$(
String className,url,uid,pwd; Y^jnlS)h
className = "oracle.jdbc.driver.OracleDriver"; S^Wqa:;
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; SG|i/K|7
uid = "system"; yz2oS|0 '
pwd = "manager"; R 6yvpH
Class.forName(className); 602eLV)
Connection cn = DriverManager.getConnection(url,uid,pwd); xZ @O"*{
2)用jndi(java的命名和目录服务)方式 zIYr0k*%
例子 VU+ s7L0
String jndi = "jdbc/db"; -{:LxE
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); FvI0 J
DataSource ds = (DataSource) ctx.lookup(jndi); dVmAMQk.g
Connection cn = ds.getConnection(); <1g 1hqK3
多用于jsp中 E-U;8cOMv
2、执行sql语句 SK c
T
1)用Statement来执行sql语句 PcSoG\-G<
String sql; dpGQ0EzH^
Statement sm = cn.createStatement(); P!6 e
sm.executeQuery(sql); // 执行数据查询语句(select) n"d)
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); l#vw
L15
2)用PreparedStatement来执行sql语句 QRmQ>
String sql; g*AD$":
sql = "insert into user (id,name) values (?,?)"; u&d v[
PreparedStatement ps = cn.prepareStatement(sql); Yqhz(&*)
ps.setInt(1,xxx); 9uq+Ve>
ps.setString(2,xxx); 8apKp?~yW
... Hj4w
i|
ResultSet rs = ps.executeQuery(); // 查询 x+:,b~Skk
int c = ps.executeUpdate(); // 更新 2wuW5H8w{
KlqJEtO_
3、处理执行结果 @8M2'R\
查询语句,返回记录集ResultSet VF!kr1n!
更新语句,返回数字,表示该更新影响的记录数 zR JKIm
ResultSet的方法 O->(9k <
1、next(),将游标往后移动一行,如果成功返回true;否则返回false 'ZZWH
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 vkd<l&zD
RAuAIiQ
4、释放连接 d7K17KiC
cn.close(); !q6V@&
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection ;pNbKf:
*sIG&
可滚动、更新的记录集 l[\,*C
1、创建可滚动、更新的Statement +uiH0iGS
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); ,Qi|g'a
该Statement取得的ResultSet就是可滚动的 PN^1
2、创建PreparedStatement时指定参数 eGypXf%
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); R
EH&kcn
ResultSet.absolute(9000); y[@j0xlO
批量更新 ZR q}g:
1、Statement e}O -I
Statement sm = cn.createStatement(); NF\^'W@N
sm.addBatch(sql1); UE`4$^qs
sm.addBatch(sql2); M>H^<N}'A
... 0)Xue9AS
sm.executeBatch() cLko
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 'SD|ObBY
2、PreparedStatement Y <i}"eI*
PreparedStatement ps = cn.preparedStatement(sql); -MW(={#
{ Y./}zCT
ps.setXXX(1,xxx); RdVis|7o
... yb.|7U?/x
ps.addBatch(); <QW1fE
} :8|3V~%m
ps.executeBatch(); *Qwhi&k
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 KRR^?
<