java 数据库基本操作 (aKZ5>>cN
1、java数据库操作基本流程 cdp0!W4Gi
2、几个常用的重要技巧: ,seFkG@1
可滚动、更新的记录集 'V!kL,
9ES
批量更新 } p'8w\C$
事务处理 j7/(sf
7kz-V.
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 TlPVHJyt
1、取得数据库连接 %g^"]
1)用DriverManager取数据库连接 FBYODw
例子 UC!5
wVY
String className,url,uid,pwd; -<oZ)OfU
className = "oracle.jdbc.driver.OracleDriver"; a-PGW2G
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; |9s wZ[
uid = "system"; 9*_uCPR
pwd = "manager"; JSjYC0e
Class.forName(className); oh&Y<d0
Connection cn = DriverManager.getConnection(url,uid,pwd); ,L%p
2)用jndi(java的命名和目录服务)方式 878tI3-
例子 `pYE[y+
String jndi = "jdbc/db"; t<lyg0f
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); WEC-<fN|Y\
DataSource ds = (DataSource) ctx.lookup(jndi); v*DFiCQD
Connection cn = ds.getConnection(); 3wNN<R
多用于jsp中 ZjD2u8e
2、执行sql语句 d| \#?W&
1)用Statement来执行sql语句 s1=u{ET
String sql; y h-9u
Statement sm = cn.createStatement(); ngqUH
sm.executeQuery(sql); // 执行数据查询语句(select) s5.k|!K
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); CjZ6NAHc
2)用PreparedStatement来执行sql语句 )/TVJAJ
String sql; 6DZ2pT:
sql = "insert into user (id,name) values (?,?)"; N7B}O*;
PreparedStatement ps = cn.prepareStatement(sql); }rxFS
<j
ps.setInt(1,xxx);
* D3
ps.setString(2,xxx); +-k`x0v
... 3mA/Nu_
ResultSet rs = ps.executeQuery(); // 查询 R7t
bxC
int c = ps.executeUpdate(); // 更新 j)@oRWL<
nP)-Y#`~7
3、处理执行结果 *EE|?vn
查询语句,返回记录集ResultSet A?V<l<EAm
更新语句,返回数字,表示该更新影响的记录数 Sl~C0eO
ResultSet的方法 e)og4
1、next(),将游标往后移动一行,如果成功返回true;否则返回false iy9VruT<