java 数据库基本操作 pHWol!
1、java数据库操作基本流程 )Dv"seH.
2、几个常用的重要技巧: x{+rx.
可滚动、更新的记录集 o XGf#>keg
批量更新 C#gQJ=!B
事务处理 KKOu":b
+[cm
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 oiklRf
1、取得数据库连接 K<V(h#(.@
1)用DriverManager取数据库连接 F2XXvxG
例子 iA%3cpIc(Z
String className,url,uid,pwd; Y}4dW'
className = "oracle.jdbc.driver.OracleDriver"; d{YhKf#~
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; [V1gj9t=,
uid = "system"; ,@<-h* m
pwd = "manager"; S46[2-v1
Class.forName(className); y{kXd1,
Connection cn = DriverManager.getConnection(url,uid,pwd); {a>)VZw_#
2)用jndi(java的命名和目录服务)方式 p4t(xm2T
例子 0}aJCJ9sx=
String jndi = "jdbc/db"; ^%\p; yhL
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); $bMeL7CN
DataSource ds = (DataSource) ctx.lookup(jndi); A@`C<O ^
Connection cn = ds.getConnection(); +[*UC"
多用于jsp中 {VI%]n{M
2、执行sql语句 y_J{+
1)用Statement来执行sql语句 5|AZ/!rb
String sql; "b2Mk-qP
Statement sm = cn.createStatement(); IMVoNKW-
sm.executeQuery(sql); // 执行数据查询语句(select) 2wu
5`Z[E
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); rPQ$e!m1Ee
2)用PreparedStatement来执行sql语句 \f._I+gJ
String sql; q.MM|;_u`
sql = "insert into user (id,name) values (?,?)"; |4dNi1{Zd
PreparedStatement ps = cn.prepareStatement(sql); uV;Z
ps.setInt(1,xxx); -'ZP_$sA
ps.setString(2,xxx); I</Nmgf
... h#;yA"j1&
ResultSet rs = ps.executeQuery(); // 查询 2b !b-
int c = ps.executeUpdate(); // 更新 G-rN?R.
ay4|N!ExO
3、处理执行结果 6Q\n<&,{
查询语句,返回记录集ResultSet X2o5Hc)l<
更新语句,返回数字,表示该更新影响的记录数 Gew0Y#/
ResultSet的方法 V1(eebi|
1、next(),将游标往后移动一行,如果成功返回true;否则返回false 2Q<_l*kk(
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 6g$+ ))g
f!1KGP
4、释放连接 v^KJU
+
cn.close(); ?t<wp3bZ
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection p%j@2U
O:D`6U+0
可滚动、更新的记录集 >o(*jZ
1、创建可滚动、更新的Statement R|tjvp-[}
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); Ndx='j0
该Statement取得的ResultSet就是可滚动的 :%s9<g;-h_
2、创建PreparedStatement时指定参数 =L&_6