java 数据库基本操作 tM^;?HL]
1、java数据库操作基本流程 2JiAd*WK
2、几个常用的重要技巧: )+n,5W
可滚动、更新的记录集 JQ"`9RNb
批量更新 L$29L:
事务处理 \K?(
`dv}a-Q)c
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 fO^e+Mz
1、取得数据库连接 >bfYy=/
1)用DriverManager取数据库连接 UCn*UX
例子 K\IYx|Hm a
String className,url,uid,pwd; 0%xR<<gir
className = "oracle.jdbc.driver.OracleDriver"; RgB6:f,
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; t."g\;
uid = "system"; c=A(o
pwd = "manager"; 9Fy\t{ks
Class.forName(className);
""1#bs{n
Connection cn = DriverManager.getConnection(url,uid,pwd); -?< Ww{
2)用jndi(java的命名和目录服务)方式 hWD !
例子 U1,~bO9
String jndi = "jdbc/db"; 0?lp/|K
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); r}/yi
DataSource ds = (DataSource) ctx.lookup(jndi); V_&GYXx(J
Connection cn = ds.getConnection(); Zm%VG(l
多用于jsp中 Gb(C#,xbK
2、执行sql语句 nG"tO'J6
1)用Statement来执行sql语句 @+'c+
String sql; }P<Qz^sr_
Statement sm = cn.createStatement(); 1~}m.ER
sm.executeQuery(sql); // 执行数据查询语句(select) yZYKwKG
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); (^sh
2)用PreparedStatement来执行sql语句 L`9TB"0R+
String sql; lGdM80f
sql = "insert into user (id,name) values (?,?)"; ]2Sfkl0
PreparedStatement ps = cn.prepareStatement(sql); 9=t#5J#O
ps.setInt(1,xxx); N\9}\Rk@
ps.setString(2,xxx); 3iE-6udCS
... [YC=d1F5
ResultSet rs = ps.executeQuery(); // 查询 9$7&URwSDI
int c = ps.executeUpdate(); // 更新 &/Eg2
Lw*;tL<,
3、处理执行结果 ]43al f F#
查询语句,返回记录集ResultSet uYFMv=>j
更新语句,返回数字,表示该更新影响的记录数 d"#gO,H0
ResultSet的方法 C%giv9a
1、next(),将游标往后移动一行,如果成功返回true;否则返回false
-Y*VgoK%
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 u~s
Sk
.z=U= _e
4、释放连接 weNzYMf%
cn.close(); s%eyW _
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection 0B=[80K;8
aSc{Ft/O
可滚动、更新的记录集 9YR]+*
1、创建可滚动、更新的Statement P DRnW
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); ePf+[pV3
该Statement取得的ResultSet就是可滚动的 Dc08D4
2、创建PreparedStatement时指定参数 &J8Z@^
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); hf;S]8|F
ResultSet.absolute(9000); Q*]$)D3n
批量更新 6}ce1|mkg/
1、Statement 41u*w2j
Statement sm = cn.createStatement(); 1hl]W+9
sm.addBatch(sql1); <0CzB"Ap
sm.addBatch(sql2); #EJhAJ
... B?+.2
sm.executeBatch() J.#(gFBBl\
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 ]b 3/Es+
2、PreparedStatement {vs 4vS6
PreparedStatement ps = cn.preparedStatement(sql); C\
tprnY
{ l^.K'Q1~a
ps.setXXX(1,xxx); $tI]rU
... XC=%H'p
ps.addBatch(); Y[2Wt%2\6
} m23+kj)+VY
ps.executeBatch(); g3Z:{@m
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 vu=me?m?(
_w 5RK(
事务的处理 J , V
1、关闭Connection的自动提交 pgT9hle/
cn.setAutoCommit(false); t)` p@]j
2、执行一系列sql语句 ?AEd(_a!q
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close MhNFW'_
Statement sm ; j`O7=-
sm = cn.createStatement(insert into user...); P`
#QGZ>
sm.executeUpdate(); [r(Qs|
sm.close(); r#A_RZ2~@
sm = cn.createStatement("insert into corp...); 7KU~(?|:h
sm.executeUpdate(); z"lqrSJ:
sm.close(); /RGNAHtIi
3、提交 @}WNKS&m
cn.commit(); blGf!4H
4、如果发生异常,那么回滚 *I0Tbc
O
cn.rollback();