java 数据库基本操作 R]sjG<
1、java数据库操作基本流程 <:7e4#
2、几个常用的重要技巧: b2f2WY |z>
可滚动、更新的记录集 VM|)\?Q
批量更新 Fl>j5[kLZ
事务处理 ,F9wc<V8
p[VCt" j
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 EGr5xR-
1、取得数据库连接 )3\rp$]1
1)用DriverManager取数据库连接 ZU@jtqq
例子 ~9;mZi1-
String className,url,uid,pwd; 8A]q!To
className = "oracle.jdbc.driver.OracleDriver"; ;B7|tajd
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; G8-d%O p
uid = "system"; 5e8-?w%e
pwd = "manager"; g\nL
n#
Class.forName(className); AezXou&
Connection cn = DriverManager.getConnection(url,uid,pwd); ';!UJWYl
2)用jndi(java的命名和目录服务)方式 "m)O13x
例子 \mit&EUh}
String jndi = "jdbc/db"; A_
z:^9
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); %a^!~qV
DataSource ds = (DataSource) ctx.lookup(jndi); Y tj>U
Connection cn = ds.getConnection(); ]
r+I D
多用于jsp中 4IE#dwZW
2、执行sql语句 W&[9x%Ba
1)用Statement来执行sql语句 Jpnp'
String sql; .@Sh,^ v
Statement sm = cn.createStatement(); RXvcy<
sm.executeQuery(sql); // 执行数据查询语句(select) H$iMP.AK
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); \/%Q PE8
2)用PreparedStatement来执行sql语句 WW@"75t
String sql; xW )8mv?4n
sql = "insert into user (id,name) values (?,?)"; `fVA.%
PreparedStatement ps = cn.prepareStatement(sql); -*j;
ps.setInt(1,xxx); 93b5S>&r
ps.setString(2,xxx); 2YEn)A@8
... 1@@]h!>k:
ResultSet rs = ps.executeQuery(); // 查询 j*\MUR=
int c = ps.executeUpdate(); // 更新 )p](*Z^
GDe$p;#"9g
3、处理执行结果 >%A=b}VS
查询语句,返回记录集ResultSet $k=rd#3
更新语句,返回数字,表示该更新影响的记录数 Du4?n8 o
ResultSet的方法 -/*{^[
1、next(),将游标往后移动一行,如果成功返回true;否则返回false ViONG]F
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 ;yoq/
r2`?Ta
4、释放连接 2a}_|#*
cn.close(); @WUCv7U
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection cl8Mv
~t$VzL1
可滚动、更新的记录集 JsdEA
1、创建可滚动、更新的Statement #f@53Pxb
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); 9Ky,oB
该Statement取得的ResultSet就是可滚动的 $>`8'I
2、创建PreparedStatement时指定参数 :udZfA\sW
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); "q8'tN><