社区应用 最新帖子 精华区 社区服务 会员列表 统计排行 社区论坛任务 迷你宠物
  • 8428阅读
  • 1回复

[JAVA]java 数据库基本操作

t_y
级别: 经院硕士
发帖
2080
铜板
4671
人品值
2716
贡献值
3
交易币
0
好评度
2087
信誉值
0
金币
0
所在楼道
java 数据库基本操作 Jo~fri([%Q  
1、java数据库操作基本流程 apfr>L3  
2、几个常用的重要技巧: j4]3}t0q  
    可滚动、更新的记录集 Y#=MN~##t  
    批量更新 T5.^ w  
    事务处理 m&'!^{av  
,j.bdlI#  
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 jcBZ#|B7;  
1、取得数据库连接 n5IQKYr g  
  1)用DriverManager取数据库连接 /m 7~-~$V  
  例子 MHye!T6fO\  
    String className,url,uid,pwd; 2\gIjXX"  
    className = "oracle.jdbc.driver.OracleDriver"; ?N!kYTR%}  
    url      = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; ~#}T|  
    uid      = "system"; b`=g#B|  
    pwd      = "manager"; K(d+t\ca  
    Class.forName(className); ~<_WYSzS  
    Connection cn = DriverManager.getConnection(url,uid,pwd); -%^'x&e  
  2)用jndi(java的命名和目录服务)方式 pv-c>8Wb6  
  例子 jh`[ Y7RJO  
    String jndi = "jdbc/db"; uhp.Yv@c  
    Context ctx = (Context) new InitialContext().lookup("java:comp/env"); zEukEA^9`  
    DataSource ds = (DataSource) ctx.lookup(jndi); {s*2d P)  
    Connection cn = ds.getConnection(); !=a]Awr\  
  多用于jsp中 8?YeaMIBB  
2、执行sql语句 q(~|roKA(  
  1)用Statement来执行sql语句  jIH^  
  String sql; uI%7jA~@  
  Statement sm = cn.createStatement(); BHZhdm@),  
  sm.executeQuery(sql); // 执行数据查询语句(select) ;YW@ 3F-h  
  sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); VYO1qj  
  2)用PreparedStatement来执行sql语句 7\R"RH-  
  String sql; .q[}e);)  
  sql  = "insert into user (id,name) values (?,?)"; V{A`?Jl6{  
  PreparedStatement ps = cn.prepareStatement(sql); ecQ,DOX|b  
  ps.setInt(1,xxx); 10OkrNQ  
  ps.setString(2,xxx); uKvdL "  
  ... mdEl CC0  
  ResultSet rs = ps.executeQuery(); // 查询 i*@PywT"i3  
  int c = ps.executeUpdate(); // 更新 woBx609Aak  
  {P_7AM  
3、处理执行结果 Fkq^2o ]  
  查询语句,返回记录集ResultSet ;z N1Qb  
  更新语句,返回数字,表示该更新影响的记录数 +{I" e,Nk  
  ResultSet的方法 %%>nM'4<  
  1、next(),将游标往后移动一行,如果成功返回true;否则返回false $AE5n>ZD$  
  2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 x-%RRm<V  
  ftl?x'P%  
4、释放连接 M6Np!0G  
  cn.close(); 5$cjCjY  
  一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection w-LENdw  
X?n=UebO^  
可滚动、更新的记录集 : T7(sf*!*  
1、创建可滚动、更新的Statement \x]\W#C  
  Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY);  P Je_qP  
  该Statement取得的ResultSet就是可滚动的 L G5_\sY!  
2、创建PreparedStatement时指定参数 Vp|?R65S*  
  PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); xSSEDfq  
  ResultSet.absolute(9000);  TO"Md["GI  
批量更新 `M 'tuQ M  
1、Statement GdVF;  
  Statement sm = cn.createStatement(); jY]51B  
  sm.addBatch(sql1); P*~ vWYH9  
  sm.addBatch(sql2); 1;V_E2?V  
  ... @DY"~c cH  
  sm.executeBatch() nw%`CnzT  
  一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 f86Z #%  
2、PreparedStatement >][D"  
  PreparedStatement ps = cn.preparedStatement(sql); cBZEyy&  
  { !Hl]&  
  ps.setXXX(1,xxx); l!&ik9m  
  ... 9!W$S[ABRB  
  ps.addBatch(); xy"'8uRi  
  } q#8yU\J|,  
  ps.executeBatch(); 2.b,8wT/  
  一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 W ulyM cJ  
  jlU6keZh`  
事务的处理 vB{i w}Hi!  
1、关闭Connection的自动提交 OWT%XUW=  
  cn.setAutoCommit(false); .SER,],P  
2、执行一系列sql语句 C c: <F_UI  
  要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close "`4ky ]  
Statement sm ; {ilz[LM8(  
sm = cn.createStatement(insert into user...); <r t$~}  
sm.executeUpdate(); +qC [X~\  
sm.close(); F@f4-NR>  
sm = cn.createStatement("insert into corp...);  -D'XxOI  
sm.executeUpdate(); Bdb}4X rL  
sm.close(); JcmJq fR  
3、提交 Dm5 Uy^F}  
  cn.commit(); wL="p) TO.  
4、如果发生异常,那么回滚 t&J A1|q  
  cn.rollback();
评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

灌水
出来混 迟早都要还
级别: 终身会员
发帖
3743
铜板
8
人品值
493
贡献值
9
交易币
0
好评度
3746
信誉值
0
金币
0
所在楼道
只看该作者 1 发表于: 2007-10-09
好久没用过JDBC连数据库了  习惯Hibernate ibatis和Toplink
描述
快速回复

您目前还是游客,请 登录注册
批量上传需要先选择文件,再选择上传
认证码:
验证问题:
10+5=?,请输入中文答案:十五