java 数据库基本操作 `OfD^Q=
1、java数据库操作基本流程 o\F>K'
2、几个常用的重要技巧: o$eo\X?J?
可滚动、更新的记录集 ^U5Qb"hz
批量更新 ),CKuq>
事务处理 RIQ-mpg~(k
CT5s`v!s
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 s`ZP2"`f
1、取得数据库连接 C1'y6{,@
1)用DriverManager取数据库连接 #i.,+Q
例子 ZNne 8
String className,url,uid,pwd; %3O))Ug5
className = "oracle.jdbc.driver.OracleDriver"; &<x.D]FA]
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; X;H\u6-|>6
uid = "system"; d<+hQ\BF,
pwd = "manager"; ]J [d8S5
Class.forName(className); .uVd'
Connection cn = DriverManager.getConnection(url,uid,pwd); a2Nxpxho
2)用jndi(java的命名和目录服务)方式 >+Ig<}p
例子 y>.t[*zT
String jndi = "jdbc/db"; 5JhvYsf3_
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); F~i ~%f,
DataSource ds = (DataSource) ctx.lookup(jndi); QyxUK}6mr
Connection cn = ds.getConnection(); pU9.#O
多用于jsp中 0^R, d M
2、执行sql语句 9Vqy<7i1
1)用Statement来执行sql语句 V y$*v
String sql; 6_<~]W&
Statement sm = cn.createStatement(); J^`5L7CO
sm.executeQuery(sql); // 执行数据查询语句(select) hf]m'5pb
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); %59uR}\
2)用PreparedStatement来执行sql语句 )l$}plT4
String sql; T\n6^@.>
sql = "insert into user (id,name) values (?,?)"; D
HT^.UM28
PreparedStatement ps = cn.prepareStatement(sql); /2zan}
ps.setInt(1,xxx); Pw| h`[h
ps.setString(2,xxx); =/_u k{
...
_XT'h;m
ResultSet rs = ps.executeQuery(); // 查询 t/Y0e#9,
int c = ps.executeUpdate(); // 更新 Bcarx<P-p
4xEw2F
3、处理执行结果 lyX3'0c
查询语句,返回记录集ResultSet Vi: ^bv
更新语句,返回数字,表示该更新影响的记录数 W^H3 =hZ
ResultSet的方法 .=9WY_@SZ
1、next(),将游标往后移动一行,如果成功返回true;否则返回false :^Pks R
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 );%H;X+x
PWyf3
4、释放连接 ~x!up9
cn.close(); A$r$g\5+
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection D/f4kkd
MW6z&+Z
可滚动、更新的记录集 DrKB;6
1、创建可滚动、更新的Statement ?WHf%Ie2(
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); # H
w(w
该Statement取得的ResultSet就是可滚动的 iX6>u4~(
2、创建PreparedStatement时指定参数 u*v<