java 数据库基本操作 ,"
R>}kPli
1、java数据库操作基本流程 Y(i?M~3\t
2、几个常用的重要技巧: z]#hWfM4B:
可滚动、更新的记录集 n.$(}A
批量更新 7 ^I:=qc72
事务处理 H~9=&p[Q
%`\]Y']R
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 !Tfij(91
1、取得数据库连接 ?ApRJm:T
1)用DriverManager取数据库连接 !oMt_k X
例子 [%8@DC'
String className,url,uid,pwd; I-:`cON=G
className = "oracle.jdbc.driver.OracleDriver"; WcGXp$M
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; gg]~2f
uid = "system"; TbNGgjT
pwd = "manager"; kL7^$
Class.forName(className); ?SX_gYe9
Connection cn = DriverManager.getConnection(url,uid,pwd); 1r4,XSk
2)用jndi(java的命名和目录服务)方式 981!2*
例子 EF;,Gjh5p
String jndi = "jdbc/db"; 31XU7A
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); 1D1b"o
DataSource ds = (DataSource) ctx.lookup(jndi); N/{?7sG&
Connection cn = ds.getConnection(); -<oZ)OfU
多用于jsp中 7:o+iP4 6
2、执行sql语句 _Y-$}KwY!
1)用Statement来执行sql语句 rx:lKoOnB
String sql; :XS"#^aJ
Statement sm = cn.createStatement(); 5u,sx664
sm.executeQuery(sql); // 执行数据查询语句(select) z\}!RBOq
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); xH$%5@~
2)用PreparedStatement来执行sql语句 i$O#%12l
String sql; 878tI3-
sql = "insert into user (id,name) values (?,?)"; h)o]TV
PreparedStatement ps = cn.prepareStatement(sql); u2lmwE
ps.setInt(1,xxx); *Q/E~4AW|t
ps.setString(2,xxx); .BL:h&h|y
... raQYn?[
ResultSet rs = ps.executeQuery(); // 查询 w-:
D
int c = ps.executeUpdate(); // 更新 .
bG{T|
%FS;>;i?
3、处理执行结果 l<RfRqjw
查询语句,返回记录集ResultSet \Da~p9T&
更新语句,返回数字,表示该更新影响的记录数 SJ(9rhB5*.
ResultSet的方法 {HuLuP0t
1、next(),将游标往后移动一行,如果成功返回true;否则返回false @,vv\M0)p
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 OK\]*r
M(S{1|,V
4、释放连接 y h-9u
cn.close(); >4'21,q
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection VRhRwdC
8|<f8Z65!
可滚动、更新的记录集 P%!q1`Eke(
1、创建可滚动、更新的Statement Mcb<[~m
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); \>[gl!B_Rr
该Statement取得的ResultSet就是可滚动的 M9g1d7%
2、创建PreparedStatement时指定参数 AIfk"2
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); S ljZ~x,!
ResultSet.absolute(9000); mh8nlB
批量更新 h.LSMU (O
1、Statement B}5XRgq
Statement sm = cn.createStatement(); ,CW%JIM
sm.addBatch(sql1); L&HzN{K
sm.addBatch(sql2); j&}B<f _6J
... ^V,@=QL3U
sm.executeBatch() q_58Lw
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 3mA/Nu_
2、PreparedStatement Ib(,P3
PreparedStatement ps = cn.preparedStatement(sql); -9Xw]I#QR
{ p,^>*/O>
ps.setXXX(1,xxx); dh,7iQ
s
... |ZuDX87
ps.addBatch(); d.1Q~&`
} g[<uwknf
ps.executeBatch(); ke</x+\F
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 |vN$"mp^a
"j;!_v>=f`
事务的处理 73#9NZR
1、关闭Connection的自动提交 {lKEZirO
cn.setAutoCommit(false); -9i+@%{/
2、执行一系列sql语句 :\T_'Shq
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close /K&