java 数据库基本操作 akmkyrz '&
1、java数据库操作基本流程 &sl0W-;0
2、几个常用的重要技巧: y\/1/WjBn
可滚动、更新的记录集 ))qy;Q,
批量更新 x`mG<Yt
事务处理 oh4E7yN
vx{}}/B]J
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 })'B<vq
1、取得数据库连接 !Z1@}`V&;
1)用DriverManager取数据库连接 0j^Kgx
例子 B`EJb71^Xy
String className,url,uid,pwd; Lc}LGq!
className = "oracle.jdbc.driver.OracleDriver"; T6'^EZZY
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; N:^n('U&j
uid = "system"; kXViWOXU^
pwd = "manager"; EfqX
y>W
Class.forName(className); N"Z{5A
Connection cn = DriverManager.getConnection(url,uid,pwd);
2IK}vDsis
2)用jndi(java的命名和目录服务)方式 %U/(|wodd
例子 %[GsD9_-
String jndi = "jdbc/db";
,>:U2%
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); 2_>N/Z4T
DataSource ds = (DataSource) ctx.lookup(jndi); W<'m:dq
Connection cn = ds.getConnection(); 91/Q9xY
多用于jsp中 Q1Kfi8h}'
2、执行sql语句 % 7hrk
1)用Statement来执行sql语句 Kf3"Wf^q
String sql; n3WlZ!$
Statement sm = cn.createStatement(); aHD]k8m z
sm.executeQuery(sql); // 执行数据查询语句(select) r-,%2y?
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); <]ox;-56
2)用PreparedStatement来执行sql语句 ldf\;Qk
String sql; [DuttFX^x
sql = "insert into user (id,name) values (?,?)"; )705V|v
PreparedStatement ps = cn.prepareStatement(sql); Zj(AJ* r
ps.setInt(1,xxx); X;$+,&M"
ps.setString(2,xxx); \$K20)
... 5%"V[lDx@
ResultSet rs = ps.executeQuery(); // 查询 F~-(:7j
int c = ps.executeUpdate(); // 更新 u* eV@KK!
/l3V3B7
3、处理执行结果 7^avpf)>
查询语句,返回记录集ResultSet +L$Xv
更新语句,返回数字,表示该更新影响的记录数 8|gIhpO?^
ResultSet的方法 [+Iz@0q
1、next(),将游标往后移动一行,如果成功返回true;否则返回false Zpt\p7WQ
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 Cp\6W[2+B
poE0{HOU
4、释放连接 Dm981t>wL
cn.close(); 10Q ]67
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection !aUs>1i
i$Ul(?
可滚动、更新的记录集 cZ,b?I"Q%
1、创建可滚动、更新的Statement Xg6Jh``
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); soxc0OlN
该Statement取得的ResultSet就是可滚动的 Ov@gh
kr
2、创建PreparedStatement时指定参数 }CSDV9).S
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY);
1~gnc|?
ResultSet.absolute(9000); l$KA)xbI
批量更新 t9lPb_70
1、Statement FaAC&F@u
Statement sm = cn.createStatement(); MpT8" /.]A
sm.addBatch(sql1); Q0sI(V#
sm.addBatch(sql2); hgG9m[?K
... :
$1?i)
sm.executeBatch() 8S
TvCH"Z_
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 "x0^#AVg
2、PreparedStatement b/K PaNv
PreparedStatement ps = cn.preparedStatement(sql); z(O Nv#}p
{ [jQp~&nY
ps.setXXX(1,xxx); &u."A3(
... `7E;VL^Y1
ps.addBatch(); `v!urE/gg%
} %@b0[ZC
ps.executeBatch(); h,:m~0gmj
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 ]h`&&B qt
LENq_@$
事务的处理 bIDj[-CDG
1、关闭Connection的自动提交 _;S-x
cn.setAutoCommit(false); >NV@R&
2、执行一系列sql语句 zaIKdI'/e
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close fUWG*o9
Statement sm ; ,Zx0%#6
sm = cn.createStatement(insert into user...);
z_$% -6
sm.executeUpdate(); BKCiIfkZ
sm.close(); 5Pc;5
o0C
sm = cn.createStatement("insert into corp...); 8Al{+gx@?
sm.executeUpdate(); v4TQX<0s
sm.close(); ktXM|#
3、提交 ?FZ HrA
cn.commit(); l'rja.\
4、如果发生异常,那么回滚 P= BZ+6DS
cn.rollback();