技术中心

这里象征着我们的态度和能力

>JDBC可滚动可更新感知更新结果集
发布者:中国IT实验室    信息来源:中国IT实验室    发布时间:2012-01-09      浏览次数:5178
分享到:

新浪微博

腾讯微博

QQ空间

豆瓣网

QQ好友

欢迎进入Java社区论坛,与200万技术人员互动交流 >>进入

  JDBC的结果集有很多类型。这些结果集有不同的特性,以满足各种需要。这在高性能的JDBC数据操作中有着重要应用。下面是一个应用实例:

  一、测试代码

  package lavasoft.common;

  import java.sql.Connection;

  import java.sql.ResultSet;

  import java.sql.SQLException;

  import java.sql.Statement;

  /**

  * JDBC可滚动可更新感知更新结果集测试

  *

  * @author leizhimin 2009-12-8 20:09:03

  */

  public class TestResultSet {

  public static void main(String[] args) {

  testScrollResultSet();

  testUpdateResultSet();

  }

  /**

  * 可更新结果集更新测试

  */

  public static void testUpdateResultSet() {

  Connection conn = DBToolkit.getConnection();

  String sql = "SELECT * FROM book";

  try {

  Statement stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);

  ResultSet rs = stmt.executeQuery(sql);

  System.out.println("---------原结果集--------");

  while (rs.next()) {

  System.out.println("[行号:" + rs.getRow() + "] " + rs.getString(1) + " " + rs.getString(2) + " " + rs.getString(3));

  }

  System.out.println("---------插入一条记录--------");

  rs.first();

  //将光标移动到插入行上

  rs.moveToInsertRow();

  //构建行数据

  rs.updateString(2, "xxxx");

  rs.updateString(3, "x");

  //插入一行

  rs.insertRow();

  System.out.println("-------------更新一条记录-------------");

  rs.absolute(3);

  //构建行数据

  rs.updateString(2, "uuuu");

  rs.updateString(3, "u");

  rs.updateRow();

  System.out.println("---------插入更新后的结果集--------");

  rs = stmt.executeQuery(sql);

  while (rs.next()) {

  System.out.println("[行号:" + rs.getRow() + "] " + rs.getString(1) + " " + rs.getString(2) + " " + rs.getString(3));

  }

  rs.close();

  stmt.close();

  } catch (SQLException e) {

  e.printStackTrace();

  } finally {

  DBToolkit.closeConnection(conn);

  }

  }

  /**

  * 可滚动结果集滚动测试

  */

  public static void testScrollResultSet() {

  Connection conn = DBToolkit.getConnection();

  String sql = "SELECT * FROM book";

  try {

  Statement stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY);

  ResultSet rs = stmt.executeQuery(sql);

  while (rs.next()) {

  System.out.println("[行号:" + rs.getRow() + "] " + rs.getString(1) + " " + rs.getString(2) + " " + rs.getString(3));

  }

[1] [2] [3] 下一页

上一篇: >JDBC接口的性能

下一篇: >jdbc连接类

4000-880-989
(24小时热线)
联系客服
微信公众号

官方公众号

小程序

©2008-2022 CORPORATION ALL Rights Reserved. 昆明奥远科技有限公司版权所有 滇ICP备09003328号-1 滇公网安备 53011102000818号
昆明那家网络公司好,新媒体运营,网站优化,网络推广,网站建设,网页设计,网站设计,网站推广,云南网站公司,昆明新媒体公司,云南网红主播,昆明SEO公司,昆明网站建设,昆明网络推广,昆明网站优化,昆明网站推广,红河网站建设,大理网络公司,曲靖网络公司,丽江网站设计,昭通网络公司,保山大数据服务,智慧高速建设,智慧校园服务,云南IDC服务商,网络安全测评,等保测评,网站关键词排名优化服务,服务客户尽超2000余家,一切尽在奥远科技,服务电话:13888956730