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

[JAVA]java 数据库基本操作

t_y
级别: 经院硕士
发帖
2080
铜板
4671
人品值
2716
贡献值
3
交易币
0
好评度
2087
信誉值
0
金币
0
所在楼道
java 数据库基本操作 >NYW{(j  
1、java数据库操作基本流程 |a1{ve[  
2、几个常用的重要技巧: Ar*^ ;/  
    可滚动、更新的记录集 |L2SFB?d=  
    批量更新 ?;[w" `"  
    事务处理 ;OqB5qd  
MZ+^-@X  
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 ls@i".[  
1、取得数据库连接 8>hwK)av  
  1)用DriverManager取数据库连接 }\J2?Et{  
  例子 {9UEq0  
    String className,url,uid,pwd; ry9T U  
    className = "oracle.jdbc.driver.OracleDriver"; >B]'fUt5a  
    url      = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; 1`ayc|9BR  
    uid      = "system"; q$I:`&  
    pwd      = "manager"; hn#1%p6t  
    Class.forName(className); !;?+>R)h  
    Connection cn = DriverManager.getConnection(url,uid,pwd); %_!bRo  
  2)用jndi(java的命名和目录服务)方式 R2Zgx\VV'  
  例子 MxT-1&XL  
    String jndi = "jdbc/db"; S<'[%ihx  
    Context ctx = (Context) new InitialContext().lookup("java:comp/env"); F~ h7{@\  
    DataSource ds = (DataSource) ctx.lookup(jndi); .o) `m9/  
    Connection cn = ds.getConnection(); C74a(Bk}H  
  多用于jsp中 yw];P o,  
2、执行sql语句 }zhGS!fO  
  1)用Statement来执行sql语句 wgCa58H76  
  String sql; M#(+c_(r  
  Statement sm = cn.createStatement(); *G* k6.9W!  
  sm.executeQuery(sql); // 执行数据查询语句(select) 8Z(Mvq]f&  
  sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); : q#Xq;Wp  
  2)用PreparedStatement来执行sql语句 qkiI/nH3  
  String sql; uj :%#u  
  sql  = "insert into user (id,name) values (?,?)"; t+9][Adf  
  PreparedStatement ps = cn.prepareStatement(sql); v`M3eh@$A  
  ps.setInt(1,xxx); ")d`dj\o  
  ps.setString(2,xxx); d_IAs  
  ... Djg,Lvhm  
  ResultSet rs = ps.executeQuery(); // 查询 Na:w]r:y  
  int c = ps.executeUpdate(); // 更新 ,7<f9 EVY  
  tQS5hwm*  
3、处理执行结果 : |>Gc39`t  
  查询语句,返回记录集ResultSet +E{|63~q  
  更新语句,返回数字,表示该更新影响的记录数 sBcPq SMby  
  ResultSet的方法 V4_=<W  
  1、next(),将游标往后移动一行,如果成功返回true;否则返回false P9T}S  
  2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 6I%5Q4Ll  
  e)(wss+d7P  
4、释放连接 U&?v:&c#&n  
  cn.close(); w@{=nD4p  
  一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection EOCN&_Z;  
6oGYnu;UZ  
可滚动、更新的记录集 BocSwf;v.  
1、创建可滚动、更新的Statement )ubiB^g'm  
  Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); gP;&e:/3  
  该Statement取得的ResultSet就是可滚动的 S:O O0<W  
2、创建PreparedStatement时指定参数 xL\0B,]  
  PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); r,h%[JKM  
  ResultSet.absolute(9000);  >r !|sC  
批量更新 RJd(~1  
1、Statement Ymg|4 %O@  
  Statement sm = cn.createStatement(); ))"6ern  
  sm.addBatch(sql1); [n :<8ho  
  sm.addBatch(sql2); }hhGu\  
  ... !O<)\ )|g  
  sm.executeBatch() "g1)f"pL  
  一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 T\D}kQM  
2、PreparedStatement ,^2>k3=  
  PreparedStatement ps = cn.preparedStatement(sql); 2.l:O2<  
  { tNbN7yI  
  ps.setXXX(1,xxx); G|!on<l&  
  ... ?.Ca|H<  
  ps.addBatch(); s+<Yg$)  
  } .=s&EEF  
  ps.executeBatch(); EwvoQ$#jv  
  一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 ]?!mS[X  
  a ?)NC  
事务的处理 >s<^M|S07  
1、关闭Connection的自动提交 ivN&HAxI@  
  cn.setAutoCommit(false); f=WDR m]  
2、执行一系列sql语句 =,6z4" )  
  要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close y ~U #veY  
Statement sm ; sM `DL  
sm = cn.createStatement(insert into user...); x8V('`}j  
sm.executeUpdate(); kZmpu?P  
sm.close(); H" 3fT0  
sm = cn.createStatement("insert into corp...); NgP&.39U  
sm.executeUpdate(); pC@{DW;V6R  
sm.close(); {#@W)4)cA  
3、提交 woK&q7Vn  
  cn.commit(); RO'7\xvn  
4、如果发生异常,那么回滚 |l]XpWV  
  cn.rollback();
评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

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

您目前还是游客,请 登录注册
欢迎提供真实交流,考虑发帖者的感受
认证码:
验证问题:
3+5=?,请输入中文答案:八 正确答案:八