java 数据库基本操作 CjD2FnjT
1、java数据库操作基本流程 j]kx~
2、几个常用的重要技巧: 2vK{Yw
可滚动、更新的记录集 i)eub`uMy
批量更新 fv}h;?C
事务处理 <<[`;"CF
]$Z aS\m
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 P=V~/,>SZ!
1、取得数据库连接 )<!y_;$A
1)用DriverManager取数据库连接 qQ^]z8g6P
例子 QQ pe.oF
String className,url,uid,pwd; TqzkF7;k4
className = "oracle.jdbc.driver.OracleDriver"; yfi.<G)S
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; )=2iGEVW
uid = "system"; cn Q(
G$kh
pwd = "manager"; e)GFJ3sW_
Class.forName(className); nIdvff
Connection cn = DriverManager.getConnection(url,uid,pwd); #knpZ'
2)用jndi(java的命名和目录服务)方式 6 Rg{^E Rf
例子 qd(`~a
String jndi = "jdbc/db"; <r_ldkZ
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); z$S)|6Q
DataSource ds = (DataSource) ctx.lookup(jndi); F4KXx^~o
Connection cn = ds.getConnection(); !m:SRNPg
多用于jsp中 BQ &|=a6
2、执行sql语句 \V}?K0#bt
1)用Statement来执行sql语句 Z^s&]
String sql; -2bu`oD
`
Statement sm = cn.createStatement(); _0ep[r
sm.executeQuery(sql); // 执行数据查询语句(select) YJF!_kg.
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); `WX @1]m
2)用PreparedStatement来执行sql语句 TLw.rEN!;
String sql; 5%uLs}{\q
sql = "insert into user (id,name) values (?,?)"; ~
/]u72?rP
PreparedStatement ps = cn.prepareStatement(sql); L%I@HB9-Q0
ps.setInt(1,xxx); O57
eq.aT
ps.setString(2,xxx); #2/k^N4r
... epR7p^`7
ResultSet rs = ps.executeQuery(); // 查询 -NHc~=m
int c = ps.executeUpdate(); // 更新 <`n T+c
jl%27Ld
3、处理执行结果 wxN'Lv=R
查询语句,返回记录集ResultSet t4~Bn<=
更新语句,返回数字,表示该更新影响的记录数 P^T]U bv"
ResultSet的方法 &n91f
1、next(),将游标往后移动一行,如果成功返回true;否则返回false c|IH|y
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 Z!v)zH\
NRgNh5/
4、释放连接 Xw_AZ-|1D
cn.close(); FK{Vnj0
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection R~PD[.\u
L;wzvz\+
可滚动、更新的记录集 hZ[,.
1、创建可滚动、更新的Statement Q6]SsV?x
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); o@XhL9
该Statement取得的ResultSet就是可滚动的 hCuUX)>Bt
2、创建PreparedStatement时指定参数 *FmY4w
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); v[A)r]"j"M
ResultSet.absolute(9000); ^FIpkhw
批量更新 J7c(qGJI2
1、Statement .T#h5[S2x
Statement sm = cn.createStatement(); 9jBP|I{xI
sm.addBatch(sql1); 0X!A'
sm.addBatch(sql2); 4'Potv@/
... |@!4BA
sm.executeBatch() f#FAi3
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 n&y'Mb
PB
2、PreparedStatement a=]tqV_
PreparedStatement ps = cn.preparedStatement(sql); N7=lSBm
{ k><k|P[|
ps.setXXX(1,xxx); MZZEqsD5[
... l`>|XUf6
ps.addBatch(); (_Ph{IN
} !?#B*JGFS
ps.executeBatch(); Psm5J80}n
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 bwG$\Oe6
}%x2Z{VF
事务的处理 I!Z=3 $,
1、关闭Connection的自动提交 FhpS#,Y$
cn.setAutoCommit(false); 1P;J%.{
2、执行一系列sql语句 /g(WCKva
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close 1Tm,#o
Statement sm ; "}fJ 2G3
sm = cn.createStatement(insert into user...); :qy< G!o
sm.executeUpdate(); Qqm'Yom%T
sm.close(); rom`%qp^
sm = cn.createStatement("insert into corp...); +#ufW%ZG
sm.executeUpdate(); -Ri/I4Xj
sm.close(); <A@}C+
3、提交 e98f+,E/
cn.commit(); .FYxVF.
4、如果发生异常,那么回滚 w#0/&\b=
cn.rollback();