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

[JAVA]java 数据库基本操作

t_y
级别: 经院硕士
发帖
2080
铜板
4671
人品值
2716
贡献值
3
交易币
0
好评度
2087
信誉值
0
金币
0
所在楼道
java 数据库基本操作 vZV+24YWb  
1、java数据库操作基本流程 u] C/RDTH  
2、几个常用的重要技巧: csn/h$`-@  
    可滚动、更新的记录集 ;>^oe:@  
    批量更新 p- 5)J&  
    事务处理 xml@]N*D#E  
4d&#NP  
java数据库操作基本流程:取得数据库连接 - 执行sql语句 - 处理执行结果 - 释放数据库连接 qz7:jq3N-{  
1、取得数据库连接 <S~_|Y*v  
  1)用DriverManager取数据库连接 (Wkli:Lq  
  例子 ' Cy^G;  
    String className,url,uid,pwd; KTn,}7vZ  
    className = "oracle.jdbc.driver.OracleDriver"; t~pA2?9@  
    url      = "jdbc:oracle:thin:@127.0.0.1:1521:orasvr; -r/G)Rs  
    uid      = "system"; S,T?(lSl  
    pwd      = "manager"; O+;0|4V%  
    Class.forName(className); /CpUq;^  
    Connection cn = DriverManager.getConnection(url,uid,pwd); a%*l]S0z"  
  2)用jndi(java的命名和目录服务)方式 4 -)'a} O  
  例子 [vki^M5i|Z  
    String jndi = "jdbc/db"; xt]Z{:.  
    Context ctx = (Context) new InitialContext().lookup("java:comp/env"); .0]4@'  
    DataSource ds = (DataSource) ctx.lookup(jndi); _'&N01  
    Connection cn = ds.getConnection(); V~LZ%NZ8  
  多用于jsp中 +3.Ik,Z}zq  
2、执行sql语句 x_1JQDE  
  1)用Statement来执行sql语句 {#q']YDe`  
  String sql; Dd|}LV  
  Statement sm = cn.createStatement(); y7SOz'd  
  sm.executeQuery(sql); // 执行数据查询语句(select) 3oX%tx  
  sm.executeUpdate(sql); // 执行数据更新语句(delete、update、insert、drop等)statement.close(); :PtpIVAosg  
  2)用PreparedStatement来执行sql语句 .4={K)kz|F  
  String sql; A(duUl~  
  sql  = "insert into user (id,name) values (?,?)"; 70_T;K6  
  PreparedStatement ps = cn.prepareStatement(sql); Cpaeo0Oq  
  ps.setInt(1,xxx); WujIaJt-  
  ps.setString(2,xxx); ~45u a  
  ... lJ]r %YlF  
  ResultSet rs = ps.executeQuery(); // 查询 ,CW]d#P|  
  int c = ps.executeUpdate(); // 更新 P8NKp O\  
  Cus=UzL  
3、处理执行结果 *ggTTHy  
  查询语句,返回记录集ResultSet Rs B o\#`  
  更新语句,返回数字,表示该更新影响的记录数 }]vj"!?a  
  ResultSet的方法 2'g< H-[  
  1、next(),将游标往后移动一行,如果成功返回true;否则返回false Pg[zRRf<  
  2、getInt("id")或getSting("name"),返回当前游标下某个字段的值 }yqRz6=YB  
  47I:o9E  
4、释放连接  d$ Mk  
  cn.close(); > 7!aZO  
  一般,先关闭ResultSet,然后关闭Statement(或者PreparedStatement);最后关闭Connection ]i*q*]x2u  
RBx`<iBe  
可滚动、更新的记录集  .Pq8C  
1、创建可滚动、更新的Statement ,4j$kR  
  Statement sm = cn.createStatement(ResultSet.TYPE_SCROLL_ENSITIVE,ResultSet.CONCUR_READ_ONLY); ($(6]?J(?7  
  该Statement取得的ResultSet就是可滚动的 .G+}Kn9!  
2、创建PreparedStatement时指定参数 q?z6|]M|u  
  PreparedStatemet ps = cn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY); X[k-J\  
  ResultSet.absolute(9000);  LoHWkNZ5:  
批量更新 ]SrKe-*:U  
1、Statement oT 8  
  Statement sm = cn.createStatement(); ->wY|7  
  sm.addBatch(sql1); yP0P-8  
  sm.addBatch(sql2); "b%hAdR  
  ... 5!#"8|oY  
  sm.executeBatch() |PH]0.m5  
  一个Statement对象,可以执行多个sql语句以后,批量更新。这多个语句可以是delete、update、insert等或兼有 hM\QqZFyp  
2、PreparedStatement *p?b"{_a  
  PreparedStatement ps = cn.preparedStatement(sql); S "oUE_>  
  { `Q26Dk  
  ps.setXXX(1,xxx); ]wne2WXE  
  ... X1<)B]y  
  ps.addBatch(); Tp`)cdcC[  
  } :&yRvu  
  ps.executeBatch(); z+" :,#  
  一个PreparedStatement,可以把一个sql语句,变换参数多次执行,一次更新。 UQ|0Aqwq  
  /p\Ymq  
事务的处理 '5ky<  
1、关闭Connection的自动提交  hPr  
  cn.setAutoCommit(false); 1@)]+* F*z  
2、执行一系列sql语句 &4*&L.hPM^  
  要点:执行每一个新的sql语句前,上一次执行sql语句的Statement(或者PreparedStatemet)必须先close t{~"vD9Am  
Statement sm ; ]kb%l"&  
sm = cn.createStatement(insert into user...); uNd;; X  
sm.executeUpdate(); ?; )(O2p  
sm.close(); }"m@~kg=  
sm = cn.createStatement("insert into corp...); "]c:V4S#`A  
sm.executeUpdate(); gY0*u+LF  
sm.close(); q 4 Ye  
3、提交 aS~k.^N  
  cn.commit(); hN\E8"To  
4、如果发生异常,那么回滚 rA=F:N 2  
  cn.rollback();
评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

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

您目前还是游客,请 登录注册
温馨提示:欢迎交流讨论,请勿纯表情、纯引用!
认证码:
验证问题:
10+5=?,请输入中文答案:十五