java 数据库基本操作 !0g+}
1、java数据库操作基本流程 RPvOup
2、几个常用的重要技巧: J]f\=;z;<a
可滚动、更新的记录集 eqSCNYN
批量更新 {)t6DH#
事务处理 ;n*N9-|.
'U)|m
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 H].
4~ 8
1、取得数据库连接 j${:Y$VmE
1)用DriverManager取数据库连接 _[SP*"
]H
例子 A}#@(ma7
String className,url,uid,pwd; F*QD\sG:
className = "oracle.jdbc.driver.OracleDriver"; b&g9A{t
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; VZ*Q|
uid = "system"; 4[]R?lL
pwd = "manager"; E (M\U5o:
Class.forName(className); Z;@F.r
Connection cn = DriverManager.getConnection(url,uid,pwd); P'D~Y#^
2)用jndi(java的命名和目录服务)方式 XbJ=lH
例子 hGH{Xp[mW
String jndi = "jdbc/db"; aW3yl}`{
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); G:.Nq,513
DataSource ds = (DataSource) ctx.lookup(jndi); %HuQc^
Connection cn = ds.getConnection(); eb:mp/
多用于jsp中 @T1/S&F=
2、执行sql语句 Nh41o0
1)用Statement来执行sql语句 d8g3hyI5\
String sql; _Bh-*l?K>
Statement sm = cn.createStatement(); =MG
sm.executeQuery(sql); // 执行数据查询语句(select) Y}"|J ~
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); [^W4%S
2)用PreparedStatement来执行sql语句 0x0.[1mB
String sql; |rf\]3 F
sql = "insert into user (id,name) values (?,?)"; 4i[3|hv'
PreparedStatement ps = cn.prepareStatement(sql); O#7fkL
ps.setInt(1,xxx); muo7KUT
ps.setString(2,xxx); tqrvcnQr^
... kT UQ8U
ResultSet rs = ps.executeQuery(); // 查询 2s
EdN$O
int c = ps.executeUpdate(); // 更新 G`w,$:,
T~%5^+[h
3、处理执行结果 )xP]rOT
查询语句,返回记录集ResultSet 3OFv_<6
更新语句,返回数字,表示该更新影响的记录数 0(3t#
ResultSet的方法 Ih`n:aA
1、next(),将游标往后移动一行,如果成功返回true;否则返回false J mFzSR?}
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 )TM ![^d
I~"-
4、释放连接 8&ZUkDGkJ
cn.close(); HqOSQ<-Fo
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection ,D3q8?j
)TyL3Z\>(
可滚动、更新的记录集 #>~$`Sg
1、创建可滚动、更新的Statement Ft`#]=IS
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); 3 %dbfT j
该Statement取得的ResultSet就是可滚动的 fQuphMOl6
2、创建PreparedStatement时指定参数 IQScsqM
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); ]$nJn+85@b
ResultSet.absolute(9000); 3=dGz^Zdv:
批量更新 =q[3/'2V$?
1、Statement I U4[}x
Statement sm = cn.createStatement(); $z@e19g T
sm.addBatch(sql1); <