java 数据库基本操作 YS~x-5OE\
1、java数据库操作基本流程 d^Wh-U
2、几个常用的重要技巧: x?F{=\z/o
可滚动、更新的记录集 . =5Jpo
批量更新 e8# 3Y+Tc
事务处理 >fdN`W}M
M#p,Z F
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 -,tYfQ;:
1、取得数据库连接 D0P% .r"v
1)用DriverManager取数据库连接 :Ry24X
例子 z~_\onC
String className,url,uid,pwd; @W,Y_8:
className = "oracle.jdbc.driver.OracleDriver"; vP2QAGk<
url = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; SrtmpQ
uid = "system"; -a[{cu{
pwd = "manager"; aVb]H0
Class.forName(className); yKI.TR#
Connection cn = DriverManager.getConnection(url,uid,pwd); QUDVsN#
2)用jndi(java的命名和目录服务)方式 r?TK@^z
例子 {P5@2u6S
String jndi = "jdbc/db"; P(;c`
Context ctx = (Context) new InitialContext().lookup("java:comp/env"); C"{on%
DataSource ds = (DataSource) ctx.lookup(jndi); YMd&+J`
Connection cn = ds.getConnection(); gK( 4<PO'
多用于jsp中 ""d>f4,S
2、执行sql语句 |gz,Ip{
1)用Statement来执行sql语句 rZv+K/6*M
String sql; :I('xVNPz
Statement sm = cn.createStatement(); ;cr6Xop#?
sm.executeQuery(sql); // 执行数据查询语句(select) \_E.%K
sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); m { fQL
2)用PreparedStatement来执行sql语句 :c t+.#
String sql; j1<1D@UO
sql = "insert into user (id,name) values (?,?)"; {p
0'Lc<3n
PreparedStatement ps = cn.prepareStatement(sql); B>ZPn6?y
ps.setInt(1,xxx); A&F4;>dms
ps.setString(2,xxx); Y
zS*p~|
... D3{lyi|8
ResultSet rs = ps.executeQuery(); // 查询 Yn>zR I
int c = ps.executeUpdate(); // 更新 *F*X_O
;%<4U^2
3、处理执行结果 o}A #-
查询语句,返回记录集ResultSet zIFL?8!H9{
更新语句,返回数字,表示该更新影响的记录数 ntV>m*^
ResultSet的方法 NO^t/(Z
1、next(),将游标往后移动一行,如果成功返回true;否则返回false J"rwWIxO*
2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 uN
62>
%Z yPK,("
4、释放连接 1,QZnF!.x
cn.close(); z-5#bOABW
一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection 0)5Sx /5'
GuWBl$|+b
可滚动、更新的记录集 fm>K4\2
1、创建可滚动、更新的Statement ]F;]<_
Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); U_'q- *W
该Statement取得的ResultSet就是可滚动的 , ~xU>L^
2、创建PreparedStatement时指定参数 "}p?pF<'0
PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); --`LP[ll
ResultSet.absolute(9000); #\BI-zt
批量更新 o(/ia3
1、Statement o$VH,2 QF
Statement sm = cn.createStatement(); >;v0zE
sm.addBatch(sql1); ;|QR-m2/
sm.addBatch(sql2); acY[?L_6J
... ;/ KF3
%
sm.executeBatch() 2TEeP7
一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 K)&XQ`&
2、PreparedStatement 8$U ZL
PreparedStatement ps = cn.preparedStatement(sql); vw]
D{OBv*
{ tQ
JH'YV
ps.setXXX(1,xxx); [V,
;X
... :s '"u]
ps.addBatch(); NB5B$q_'#
} #.+*G`m
ps.executeBatch(); XhAcC
一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 }]+}Tipd
>5O y^u6Ly
事务的处理 $Wzv$4;
1、关闭Connection的自动提交 [KI`e
cn.setAutoCommit(false); 0Y*gJ!a
2、执行一系列sql语句 MZW
Y
要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close OCO,-(
Statement sm ; }|"*"kxi!
sm = cn.createStatement(insert into user...); ,
)pt_"-XA
sm.executeUpdate(); jQeE07g
sm.close(); TL{pc=eBo
sm = cn.createStatement("insert into corp...); N vHy'
sm.executeUpdate(); GdeR#%z
sm.close(); iH}rI'U.
3、提交 (Zn3-t*
cn.commit(); lEbR) B,
4、如果发生异常,那么回滚 mRnzP[7-\)
cn.rollback();