Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 360|回复: 0

[JDBC学习]jdbc中的离线数据集(RowSet)简单入门

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-10-11 05:17:40 | 显示全部楼层 |阅读模式
    如果在开发应用的时候没有使用任何持久层框架,而是直接使用jdbc 的api编程的话,大家最长使用的就是ResultSet接口进行数据的读取了,但是大家也会觉得很不方便,因为ResultSet是在线的数据集,在读取数据的过程中不能断开数据库联接,只有读取数据完成后才能close掉相关对象。

         其实java也提供了离线的数据集,那就是RowSet接口以及相关的 子接口。而且sun在jdk里面提供一个默认的实现,而且象oracle这样比较大型的数据库驱动里面也提供自己的RowSet实现。

         下面以sun的默认 实现来说明离线数据的使用吧,数据库为sql Server 2000,连接的数据库为Northwind。
       
      
       
       
         
       

         
       
      
    1. import java.sql.Connection;
    2. import java.sql.DriverManager;
    3. import java.sql.ResultSet;
    4. import java.sql.SQLException;
    5. import java.sql.Statement;
    6. import javax.sql.RowSet;
    7. import com.sun.rowset.CachedRowSetImpl;
    8. public class RowSetDemo {
    9.     public static RowSet query(Connection connection, String sql)
    10.             throws SQLException {
    11.         //使用sun的默认RowSet实现
    12.         CachedRowSetImpl rowset = new CachedRowSetImpl();
    13.         //查询没有任何变化
    14.         Statement statement = connection.createStatement();
    15.         ResultSet rs = statement.executeQuery(sql);
    16.         //这里就是填充离线集
    17.         rowset.populate(rs);
    18.         //都可以关闭了,爽吧
    19.         rs.close();
    20.         statement.close();
    21.         return rowset;
    22.     }

    23.     public static void main(String[] args) throws Exception {
    24.         Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
    25.         String connectionUrl = "jdbc:sqlserver://127.0.0.1:1433;database=Northwind;user=sa;password=huhuiyu";
    26.         Connection connection = DriverManager.getConnection(connectionUrl);
    27.         RowSet rs = query(connection, "select * from Customers order by CustomerID;");
    28.         //关闭连接也没有关系了。
    29.         connection.close();
    30.         //和ResultSet使用一样。
    31.         while (rs.next()) {
    32.             System.out.print(rs.getString(1) + " : ");
    33.             System.out.println(rs.getString("CompanyName"));
    34.         }
    35.     }
    36. }
    37. 运行上面的例子就会将Customers的前两列的数据显示出来。其实RowSet还可以完成分页的功能。请看下面的方法。

    38. public static RowSet query(Connection connection, String sql, int pageSize,
    39.             int pageNumber) throws SQLException {
    40.         CachedRowSetImpl rowset = new CachedRowSetImpl();
    41.         //要是可以滚动的结果集
    42.         Statement statement = connection.createStatement(
    43.                 ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY);
    44.         ResultSet rs = statement.executeQuery(sql);
    45.         //设定分页大小
    46.         rowset.setPageSize(pageSize);
    47.         //计算一下开始游标位置
    48.         int skip=(pageNumber - 1) * pageSize + 1;
    49.         //可以填充了
    50.         rowset.populate(rs, skip);
    51.         rs.close();
    52.         statement.close();
    53.         return rowset;
    54.     }
    55.     public static void main(String[] args) throws Exception {
    56.         Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
    57.         String connectionUrl = "jdbc:sqlserver://127.0.0.1:1433;database=Northwind;user=sa;password=huhuiyu";
    58.         Connection connection = DriverManager.getConnection(connectionUrl);
    59.         //分页查询
    60.         RowSet rs = query(connection, "select * from Customers order by CustomerID;",5,2);
    61.         //关闭连接也没有关系了。
    62.         connection.close();
    63.         //和ResultSet使用一样。
    64.         while (rs.next()) {
    65.             System.out.print(rs.getString(1) + " : ");
    66.             System.out.println(rs.getString("CompanyName"));
    67.         }
    68.     }
    69. 如果你不使用持久层,那么使用离线数据集可以很好的解决分页和数据库连接的问题。
    70. 希望这篇入门的教程能够帮助到你。
    复制代码


      
      
       
       

         
       

         
       
      
    复制代码
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-26 07:38 , Processed in 0.295312 second(s), 36 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表