java 数据库基本操作 uP\?y(="
1、java数据库操作基本流程 OXy>Tlv
2、几个常用的重要技巧: b]v.jgD
可滚动、更新的记录集 n{dl-P
批量更新 @'.(62v
事务处理 Ctpr.
fZ2>%IxG}
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 G 2]/g
1、取得数据库连接 3%?01$k
1)用DriverManager取数据库连接 !7MC[z(|N
例子 NJfI9 L
String className,url,uid,pwd; q<L>r?T[
className = "oracle.jdbc.driver.OracleDriver"; eeX^zaKl]
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; x:W nF62
uid = "system"; cD&53FPXC
pwd = "manager"; <0OZ9?,dm
Class.forName(className); Y/1KvF4)k
Connection cn = DriverManager.getConnection(url,uid,pwd); Y27x;U
2)用jndi(java的命名和目录服务)方式 {=WTAgP
例子 e_Na_l]
String jndi = "jdbc/db"; D2 o,K&V
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); bce>DLF
DataSource ds = (DataSource) ctx.lookup(jndi); Az29?|e
Connection cn = ds.getConnection(); ,E{z+:Es
多用于jsp中
h:iK;
2、执行sql语句 @^8tk3$Y
1)用Statement来执行sql语句 -lr)z=})
String sql; \2(Uqf#_
Statement sm = cn.createStatement(); rPoPs@CBD
sm.executeQuery(sql); // 执行数据查询语句(select) F-?K]t#
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); a?bSMt}
2)用PreparedStatement来执行sql语句 Q}p+/-U\
String sql; aqq7u5O1r
sql = "insert into user (id,name) values (?,?)"; w]b3,b
PreparedStatement ps = cn.prepareStatement(sql); .i[rd4MCK
ps.setInt(1,xxx); %|L+~ =
ps.setString(2,xxx); QiB^U^f
... rQ -pD
ResultSet rs = ps.executeQuery(); // 查询 zr~hGhfq
int c = ps.executeUpdate(); // 更新 SoZ$1$o2
/t=R~BJu
3、处理执行结果 \.+.VK
查询语句,返回记录集ResultSet +uMOT#KjR
更新语句,返回数字,表示该更新影响的记录数 4G`7]<
ResultSet的方法 s`W\`w}
1、next(),将游标往后移动一行,如果成功返回true;否则返回false s&