java 数据库基本操作 3l''
1、java数据库操作基本流程 mwqe@7
2、几个常用的重要技巧: P'CDV3+
可滚动、更新的记录集 -]vPF|
批量更新 c9xc@G!
事务处理 ,W&::/2<7
RVe UQ%
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 [=KA5c<
1、取得数据库连接 F$&{@hd
1)用DriverManager取数据库连接 =5X(RGK
例子 w}QU;rl8q
String className,url,uid,pwd; -D30(g{O
className = "oracle.jdbc.driver.OracleDriver"; NYN(2J
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; "( P-VX
uid = "system"; #Q_
d
pwd = "manager"; x4bj?=+
Class.forName(className); 7<3eB)S
Connection cn = DriverManager.getConnection(url,uid,pwd); UZRCJ
2)用jndi(java的命名和目录服务)方式 C{Er%
例子 O'<cEv'B*
String jndi = "jdbc/db"; g_t1(g*s
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); SAw. 6<Wy-
DataSource ds = (DataSource) ctx.lookup(jndi); l?LP:;S
Connection cn = ds.getConnection(); Lr`G. e
多用于jsp中 El`f>o+EJ
2、执行sql语句 Rd{#cW~
1)用Statement来执行sql语句 ZU-vZD>
String sql; N| L Ey
Statement sm = cn.createStatement(); mg7Q~SLL{
sm.executeQuery(sql); // 执行数据查询语句(select) 9-?[%8
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close();
d365{
2)用PreparedStatement来执行sql语句 )'gO?cN
String sql; C'jE'B5b
sql = "insert into user (id,name) values (?,?)"; Qh.
:
N
PreparedStatement ps = cn.prepareStatement(sql); a6fqtkZ x
ps.setInt(1,xxx); 00)=3@D
ps.setString(2,xxx); jZvQMW
... 8g CQ0w<
ResultSet rs = ps.executeQuery(); // 查询 P~"`Og+
int c = ps.executeUpdate(); // 更新 A~UDtXN*4
PE-P(T3s[8
3、处理执行结果 jI9Kn41
查询语句,返回记录集ResultSet B^u qu
更新语句,返回数字,表示该更新影响的记录数 Ss~dK-{e7
ResultSet的方法 (VzabO
1、next(),将游标往后移动一行,如果成功返回true;否则返回false `^7ARr/
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 92HxZ*t7km
_~b$6Nf!83
4、释放连接 2m/=0sb\{
cn.close(); U[ $A=e?\Y
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection N [iv.B
;^j2>Azn
可滚动、更新的记录集 $5)ZaYx<
1、创建可滚动、更新的Statement HC*V\vz
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); d,9YrwbD
该Statement取得的ResultSet就是可滚动的 5U^
2、创建PreparedStatement时指定参数 4 06.6jmv
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); E1e#E3Yq}s
ResultSet.absolute(9000); " %)zTH
批量更新 :7+E
fu
1、Statement 7 Ed6o
Statement sm = cn.createStatement(); * -Kf
sm.addBatch(sql1); [:!D.@h|
sm.addBatch(sql2); hVAP
) "5
... ^KK6 d
sm.executeBatch() a:(.{z?nM
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 s1eGItx[w
2、PreparedStatement ?!J{Mrdn
PreparedStatement ps = cn.preparedStatement(sql); m
pWmExQ
{ S%7^7MSqA
ps.setXXX(1,xxx); BiUOjQC#
... .v3~2r*&
ps.addBatch(); naT;K0T=
} . !|3a
ps.executeBatch(); nUL8*#p-
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 s2-p-n
Uxq9H
事务的处理 cH!w;Ub]
1、关闭Connection的自动提交 {)QSxO
cn.setAutoCommit(false); noBGP/Av=:
2、执行一系列sql语句 7EKQE>xj
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close W1
qE,%cx
Statement sm ; ^&W(|R-,J&
sm = cn.createStatement(insert into user...); {u}Lhv
sm.executeUpdate(); K9X0/
sm.close(); P7Ws$7x
sm = cn.createStatement("insert into corp...); fQ^45ulz
sm.executeUpdate(); k2xOu9ncEj
sm.close(); 8W|qm;J98
3、提交 ^=nJ,-(h_
cn.commit(); rU/V~;#%
4、如果发生异常,那么回滚 kR0d]"dr
cn.rollback();