java 数据库基本操作 1\=)b< y
1、java数据库操作基本流程 Waj6.PCFm
2、几个常用的重要技巧: >Olg
lUzA
可滚动、更新的记录集 -Id4P _y
批量更新 y$Sn3_9 V
事务处理 3~;LNi
-uIu-a]
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 3'}(:X(
1、取得数据库连接 "9jt2@<
1)用DriverManager取数据库连接 aJ}y|+Cj
例子 k(pI5N}pJZ
String className,url,uid,pwd; X+z!?W*a
className = "oracle.jdbc.driver.OracleDriver"; P
hs4]!
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; &q^\*<B.^
uid = "system"; @#hd8_)A.
pwd = "manager"; 7IB<0
Class.forName(className); WUm83"
Connection cn = DriverManager.getConnection(url,uid,pwd); D>|m8-@]
2)用jndi(java的命名和目录服务)方式 /bv1R5
例子 Q0K2md_%x
String jndi = "jdbc/db"; N_rz~$|@9
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); ?n)d: )Ud"
DataSource ds = (DataSource) ctx.lookup(jndi); ~1]4 J(+
Connection cn = ds.getConnection(); ijEMS1$=7
多用于jsp中 _CO?HX5ek
2、执行sql语句 ?`bi8 Ck
1)用Statement来执行sql语句 N DZ :`D
String sql; 1@rI4U@D
Statement sm = cn.createStatement(); v;AsV`g
sm.executeQuery(sql); // 执行数据查询语句(select) }:<`L\8q\
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); 4$#nciAe
2)用PreparedStatement来执行sql语句 tgSl(.
String sql; i t.Lh'N;T
sql = "insert into user (id,name) values (?,?)"; UmUw>+A
PreparedStatement ps = cn.prepareStatement(sql); SR)G!9z_/
ps.setInt(1,xxx); >?aPXC
ps.setString(2,xxx); {AUhF}O
... mSF>~D1_
ResultSet rs = ps.executeQuery(); // 查询 VW: WB.K$
int c = ps.executeUpdate(); // 更新 Q>Voa&tYn
z SDRZ!
3、处理执行结果 v._Q XcE
查询语句,返回记录集ResultSet \{``r
更新语句,返回数字,表示该更新影响的记录数 G_vWwH4XtL
ResultSet的方法 _;L%? -2c
1、next(),将游标往后移动一行,如果成功返回true;否则返回false `2-6Qv
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 +z}O*,M"q
^YG'p?r.s
4、释放连接 (k/[/`3ST
cn.close(); U l8G R
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection #JMww
kDbDG,O
可滚动、更新的记录集 m}ZkNWH
1、创建可滚动、更新的Statement E[q:65xl
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); E-gI'qG\(
该Statement取得的ResultSet就是可滚动的 .'foS>W=t
2、创建PreparedStatement时指定参数 tljZE)
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); <LL+\kfTZO
ResultSet.absolute(9000); Sk7l&B
批量更新 nb-]fa
1、Statement %3b;`Oa
Statement sm = cn.createStatement(); #gn{X!;-;
sm.addBatch(sql1); _3@[S
F
sm.addBatch(sql2); yvR3|
... `#@#eZ
sm.executeBatch() 7QV@lR<C2R
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 )aSj!X'`;
2、PreparedStatement do,ZCn
PreparedStatement ps = cn.preparedStatement(sql); E)w6ZwV
{ &U*MLf83`
ps.setXXX(1,xxx); a7$-gW"Z(,
... (zbV-4C
ps.addBatch(); BNi6I\wa
} ^u2unZ9BK!
ps.executeBatch(); pRR1k?
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 m8M2ka
= VIU
事务的处理 stGk*\>U'
1、关闭Connection的自动提交 ?R-4uG[(
cn.setAutoCommit(false); bd|ZhRsL
2、执行一系列sql语句 N;Hoi8W
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close >A&D/kMO
Statement sm ; @}9*rWJIE
sm = cn.createStatement(insert into user...); P:D@5
sm.executeUpdate(); qZQB"Q.*
sm.close(); @yV.Yx"p_
sm = cn.createStatement("insert into corp...); f2h`bO
sm.executeUpdate(); ;OC~,?O5
sm.close(); oZ]^zzoEcg
3、提交 v7-z<'?s~
cn.commit(); $-^
;Jl
4、如果发生异常,那么回滚 LV}Z[\?
cn.rollback();