java 数据库基本操作 6VP`evan
1、java数据库操作基本流程 F~:O.$f]G
2、几个常用的重要技巧: w]b,7QuNz
可滚动、更新的记录集 $
,SF@BhO
批量更新 9Jf)!o8
事务处理 i,A#&YDl
{Gq*e/
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 <ljI;xE
1、取得数据库连接 %J:SO_6
1)用DriverManager取数据库连接 ,;?S\V
例子 Ji1Pz)fq
String className,url,uid,pwd; ?[<Tx-L
className = "oracle.jdbc.driver.OracleDriver"; tM-^<V&
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; Hs?e0Z=N
uid = "system"; E!BPE>
pwd = "manager"; 7!,YNy%
Class.forName(className); Aa0b6?Jm
Connection cn = DriverManager.getConnection(url,uid,pwd); Oa;X+
2)用jndi(java的命名和目录服务)方式 EN{]Qb06A
例子 XC 7?VE
String jndi = "jdbc/db"; TD[EQ
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); C51bc6V
DataSource ds = (DataSource) ctx.lookup(jndi); CQ`=V2:"ON
Connection cn = ds.getConnection(); |Fm6#1A@
多用于jsp中 BqDKT
2、执行sql语句 =S '%`] f?
1)用Statement来执行sql语句
~>O)
String sql; ;6@r-r
Statement sm = cn.createStatement(); 2?m.45`
sm.executeQuery(sql); // 执行数据查询语句(select) D|Iur W1f
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); %75xr9yOP
2)用PreparedStatement来执行sql语句 }i{sg#
String sql; UYk>'\%H0
sql = "insert into user (id,name) values (?,?)"; w-Nhs6
PreparedStatement ps = cn.prepareStatement(sql); 5D M"0
ps.setInt(1,xxx); -9RDr\&`(
ps.setString(2,xxx); du$|lxC
... W$U0[^1
ResultSet rs = ps.executeQuery(); // 查询 ;.xoN|Per
int c = ps.executeUpdate(); // 更新 J q{7R
}X
GEX:1K
3、处理执行结果 r`)L~/
查询语句,返回记录集ResultSet q~CA0AR
更新语句,返回数字,表示该更新影响的记录数 H&r,FmI@
ResultSet的方法 08X_}97#WF
1、next(),将游标往后移动一行,如果成功返回true;否则返回false :m86
hBE.
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 D=:04V}2+
!D!~^\
4、释放连接 DG4d"Jy
cn.close(); #;n+YM">:
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection x21dku<6K[
0 a]/%y3V
可滚动、更新的记录集 ??TMSH
1、创建可滚动、更新的Statement syU9O&<
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); y/e2l
该Statement取得的ResultSet就是可滚动的 n JPyM/p
2、创建PreparedStatement时指定参数 {t};-q!v$j
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); ycFio ,
ResultSet.absolute(9000); GgaTn!mJt
批量更新 Dnc(l(
1、Statement R52I=
a5,*
Statement sm = cn.createStatement(); zF5uN:-s
sm.addBatch(sql1); Ii7QJ:^
sm.addBatch(sql2); y_xnai
... aP'"G^F
sm.executeBatch() omWJJ|b~
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 ikE<=:pe
2、PreparedStatement K)TrZ 2
PreparedStatement ps = cn.preparedStatement(sql); 7~#:>OjW
{ E\gim<]
ps.setXXX(1,xxx); >]o}}KF?
... .0R v(Y
ps.addBatch(); "[}O"LTQ
} V\(:@0"
ps.executeBatch(); %OgS^_tu
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 Sq:0w
olLfko4$*V
事务的处理 qY\f'K}Q*
1、关闭Connection的自动提交 }j,[ 1@S
cn.setAutoCommit(false); L[5=h
2、执行一系列sql语句 Xl@cHO=i
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close 6<K6Y5<6
Statement sm ; 4v[~r1!V
sm = cn.createStatement(insert into user...); qj cp65^
sm.executeUpdate(); NEa>\K<\
sm.close(); p4V eRJk%
sm = cn.createStatement("insert into corp...); zhY+x<-
sm.executeUpdate(); *T0q|P~o%
sm.close(); k6=nO?$
3、提交 `9k0Gd
cn.commit(); ie-vqLc
4、如果发生异常,那么回滚 zE;bBwy&
cn.rollback();