java 数据库基本操作 !3o/c w9
1、java数据库操作基本流程 Mc,p]{<<AV
2、几个常用的重要技巧: e@&2q{Gi=
可滚动、更新的记录集 Z-M4J;J@}
批量更新 2wgcVQ
Awa
事务处理 v&7x ~!O
\&U"7gSL
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接
bjN"H`Q
1、取得数据库连接 vV*/"'>
1)用DriverManager取数据库连接 JeAyT48!M
例子 wRq
f'
String className,url,uid,pwd; FI)0.p
className = "oracle.jdbc.driver.OracleDriver"; !!mGsgnW
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; F5M{`:/
uid = "system"; 8%xiHPVg
pwd = "manager"; ~H"-km"@
Class.forName(className); ey\(*Tu9
Connection cn = DriverManager.getConnection(url,uid,pwd); ?,C'\8'
2)用jndi(java的命名和目录服务)方式 O* )BJOPa
例子 Zm(}~C29
String jndi = "jdbc/db"; Uo[`AzD3
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); Ye^xV,U@
DataSource ds = (DataSource) ctx.lookup(jndi); ,S~A]uH'
Connection cn = ds.getConnection(); E/D@;Ym18
多用于jsp中 3wfJ!z-E8
2、执行sql语句 U.<a d
1)用Statement来执行sql语句 c:s[vghH^#
String sql; 6\%#=GG
Statement sm = cn.createStatement(); ZW
5FL-I
sm.executeQuery(sql); // 执行数据查询语句(select) nE:Wl
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); =,08D^ xY
2)用PreparedStatement来执行sql语句 B*^QTJ
String sql; L:jv%;DM
sql = "insert into user (id,name) values (?,?)"; F$9+WS`c
PreparedStatement ps = cn.prepareStatement(sql); 2%MS$Fto
ps.setInt(1,xxx); |Z$)t%'
ps.setString(2,xxx); qSaCl6[Do
... E.^u:0:P
ResultSet rs = ps.executeQuery(); // 查询 k\ZU%"^J
int c = ps.executeUpdate(); // 更新 $]?M[sL\N7
W=2]!%3#
3、处理执行结果 ;)sC{ "Jb
查询语句,返回记录集ResultSet 5 L-6@@/
更新语句,返回数字,表示该更新影响的记录数 zCu+Oi6
ResultSet的方法 nQn=zbZ3
1、next(),将游标往后移动一行,如果成功返回true;否则返回false 9A}y^=!`
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 Xj:\B] v]
'%a:L^a?
4、释放连接 (D\`:1g
cn.close(); [&zSY