java 数据库基本操作 &oA p[]
1、java数据库操作基本流程 !uC`7a
2、几个常用的重要技巧: ~#doJ:^H3
可滚动、更新的记录集 .^?^QH3
批量更新 M"E ]r=1
事务处理 SS4'yaQ
nA!Xb'y&
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 2'R&K
1、取得数据库连接 NXwlRMbo
1)用DriverManager取数据库连接 97$1na3gq
例子 vYYLn9}5
String className,url,uid,pwd; Oy @vh>RY
className = "oracle.jdbc.driver.OracleDriver"; :+Pl~X"_
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; /,>@+^ 1
uid = "system"; 7_AR()CM
pwd = "manager"; @Ju!|G9z/p
Class.forName(className); ' O\me
Connection cn = DriverManager.getConnection(url,uid,pwd); d/Sx+1
"{T
2)用jndi(java的命名和目录服务)方式 tRqg')y
例子 v{R:F
String jndi = "jdbc/db"; qJ;T$W=NG
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); /K#t$O4
DataSource ds = (DataSource) ctx.lookup(jndi); `OY_v=}
Connection cn = ds.getConnection(); rKP;T"?;
多用于jsp中 F-=W7 D:[c
2、执行sql语句 8:BPXdiK
1)用Statement来执行sql语句 =Yxu {]G
String sql; N"i'[!H%
Statement sm = cn.createStatement(); ozs
xqN
sm.executeQuery(sql); // 执行数据查询语句(select) fP>K!@!8
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); B:YUb{CJ
2)用PreparedStatement来执行sql语句 Lv;R8^n
String sql; ty8\@l
sql = "insert into user (id,name) values (?,?)"; AT#&`Ew
PreparedStatement ps = cn.prepareStatement(sql); K%Sy~6iD&
ps.setInt(1,xxx); 67uUeCW
ps.setString(2,xxx); p'2ZDd=v
... |JpLMUG
ResultSet rs = ps.executeQuery(); // 查询 ^JDiI7
int c = ps.executeUpdate(); // 更新 EZm6WvlxSI
#&Zb8HAj
3、处理执行结果 x<
Td
查询语句,返回记录集ResultSet 1 :xN )M,s
更新语句,返回数字,表示该更新影响的记录数 cuJ%;q=;
ResultSet的方法 pGZI697
1、next(),将游标往后移动一行,如果成功返回true;否则返回false !l7eB@O
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 FW)G5^Tf
0]dL;~0y.
4、释放连接 JRMe(,u
cn.close(); (6C%w)8'
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection UB3b
}gE?ms4$
可滚动、更新的记录集 0Ywqv)gg
1、创建可滚动、更新的Statement $-dz1}
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY);
*mQOW]x%
该Statement取得的ResultSet就是可滚动的 R@=Bk(h
2、创建PreparedStatement时指定参数 f
IUz%YFn
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); EwSE;R -
ResultSet.absolute(9000); M(,npW
批量更新
S[o_$@|
1、Statement t]Ey~-Rx
Statement sm = cn.createStatement(); i,=CnZCh
sm.addBatch(sql1); mQQ5>0^m
sm.addBatch(sql2); M1Jnn4w*d
... ,q
yp2Y7
sm.executeBatch() D0?l$]aE
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 _v2K1 1
2、PreparedStatement Y'NQt?h
PreparedStatement ps = cn.preparedStatement(sql); Z8??+d=
{ tqY)
ps.setXXX(1,xxx); o=`FGowF
... h9)QQPP
ps.addBatch(); H26'8e
} tA+ c
ps.executeBatch(); VWoxi$3v
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 f#:7$:{F1
D. 2HM
事务的处理 ~
#Gu:
1、关闭Connection的自动提交 'l$<DcBj
cn.setAutoCommit(false); F=C8U$'S
2、执行一系列sql语句 (ilU<Ht
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close v*Qr(4
Statement sm ; n/_cJD\
sm = cn.createStatement(insert into user...); }hOExTz
sm.executeUpdate(); RHo|&.B;+
sm.close(); |qS<{WZ!h
sm = cn.createStatement("insert into corp...); #NM.g
sm.executeUpdate(); t
7D2k2x9
sm.close(); W?m?r.K?
3、提交 kI974:e42
cn.commit(); DiF=<} >x
4、如果发生异常,那么回滚 p1 tfN$-
cn.rollback();