java 数据库基本操作 ?'dsiA[
1、java数据库操作基本流程 '8$*gIQ8
2、几个常用的重要技巧: fi6i{(K
可滚动、更新的记录集 O_u2V'jy9
批量更新 FXi"o
$N
事务处理 ~F
,mc.
-J$,W`#z
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 X_6h8n}i
1、取得数据库连接 \LQ?s)~
1)用DriverManager取数据库连接 6!e I=h2P
例子 "?<$>\@;
q
String className,url,uid,pwd; lLb"><8a
className = "oracle.jdbc.driver.OracleDriver"; kDz!v?Z2+B
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; i^2yq&uT(
uid = "system"; Gidh7x
pwd = "manager"; ]26
Q*.1~
Class.forName(className); (")IU{>c6
Connection cn = DriverManager.getConnection(url,uid,pwd); 9mEt**s
Ur
2)用jndi(java的命名和目录服务)方式 8 )W{C>
例子 ?%RN? O(
String jndi = "jdbc/db"; Y30e7d* qr
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); E9]/sFA-]
DataSource ds = (DataSource) ctx.lookup(jndi); ZT\=:X*e
Connection cn = ds.getConnection(); "5+x6/9b
多用于jsp中 Z?7XuELKV
2、执行sql语句 0KQDw
1)用Statement来执行sql语句 8hK\Ya:mP
String sql; Z+qTMm
Statement sm = cn.createStatement(); ,'KQF C
sm.executeQuery(sql); // 执行数据查询语句(select) :UMtknV
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); _h=kjc}[.O
2)用PreparedStatement来执行sql语句 M+mO4q6
String sql; d'4^c,d
sql = "insert into user (id,name) values (?,?)"; ^"g # !
PreparedStatement ps = cn.prepareStatement(sql); ]W-7 U_
ps.setInt(1,xxx); uTemAIp
$u
ps.setString(2,xxx); COF_a%
... l Wa4X#~.
ResultSet rs = ps.executeQuery(); // 查询 '_nJ DM
int c = ps.executeUpdate(); // 更新 U',9t
/n9yv
3、处理执行结果 zj ?^,\{A
查询语句,返回记录集ResultSet =sR]/XSK
更新语句,返回数字,表示该更新影响的记录数 QL<uQ`>(
ResultSet的方法 &g{b5x{iD
1、next(),将游标往后移动一行,如果成功返回true;否则返回false o
IUjd
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 b R6g^Yf
&_