java 数据库基本操作 x>MY_?a
1、java数据库操作基本流程 > m##JzWLr
2、几个常用的重要技巧: O_|p{65
可滚动、更新的记录集 ky{-NrK
批量更新 8BggK6X
事务处理 dH+oV`
)jm u*D5N
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 9p%8VDF=
1、取得数据库连接 Pskg68W
1)用DriverManager取数据库连接 +^V%D!.$@
例子 nI<Ab_EB
String className,url,uid,pwd; |emZZj
className = "oracle.jdbc.driver.OracleDriver"; ]?n~?dD{]
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; j[&C6l+wH
uid = "system"; =7 ${bp!
pwd = "manager"; p'YNj3&u
Class.forName(className); zH1:kko
Connection cn = DriverManager.getConnection(url,uid,pwd); Q2RO&dL
9
2)用jndi(java的命名和目录服务)方式 vw/X
例子 D",~?
String jndi = "jdbc/db"; &46Ro|XE`
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); ?%wM 8?
DataSource ds = (DataSource) ctx.lookup(jndi); p<AzpkU,A
Connection cn = ds.getConnection(); Vv~:^6il
多用于jsp中 @Yzc?+x
2、执行sql语句 :yE7jXB
1)用Statement来执行sql语句 pb=yQ}.
String sql; MP%pEUomev
Statement sm = cn.createStatement(); V8IEfU
sm.executeQuery(sql); // 执行数据查询语句(select) Q0-}!5`E1$
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); -?PXj)<
2)用PreparedStatement来执行sql语句 JN<IMH
String sql; c(!8L\69V}
sql = "insert into user (id,name) values (?,?)";
>TQnCG=
PreparedStatement ps = cn.prepareStatement(sql); 2kQa3Pan
ps.setInt(1,xxx); qFg"!w
ps.setString(2,xxx); E|5lm
... H/BU2s a
ResultSet rs = ps.executeQuery(); // 查询 t9+ME|
int c = ps.executeUpdate(); // 更新 V.12
u<a =TPAU
3、处理执行结果 sN9
SuQ
查询语句,返回记录集ResultSet EE[JXoke
更新语句,返回数字,表示该更新影响的记录数 /{+77{#Qn
ResultSet的方法 \<4Hp_2?
1、next(),将游标往后移动一行,如果成功返回true;否则返回false fk
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 e+7x &-+
oar`xH$C
4、释放连接 X/-u$c
cn.close(); Q2HULz{
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection wC4:OJ[d
&W:R#/|
可滚动、更新的记录集 ;,Q6AS!
1、创建可滚动、更新的Statement /;\{zA$uC=
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); d@0&
该Statement取得的ResultSet就是可滚动的 *m9,_~t
2、创建PreparedStatement时指定参数 6d#
V
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); (v$$`zh
ResultSet.absolute(9000); s2M|ni=
批量更新 {rWFgn4Li
1、Statement h!UB#-
Statement sm = cn.createStatement(); /ng+IC3
sm.addBatch(sql1); u=9)A9
sm.addBatch(sql2); a<ztA:xt|1
... +\@WOs
sm.executeBatch() yHt
`kb2
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 O]N
8QH
2、PreparedStatement ~Y /55uC
PreparedStatement ps = cn.preparedStatement(sql); Vs~!\<?
{ hY-;Vh0J
ps.setXXX(1,xxx); )OgQ&,#
... T{Rhn V1
ps.addBatch(); o6~9.~_e
} gBCO>nJws
ps.executeBatch(); ~76qFZe-
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 -L)b;0%
-)2sR>`A%
事务的处理 :KL5A1{
1、关闭Connection的自动提交 1xF<c<
cn.setAutoCommit(false); Z$&