文档章节

使用RowSet

 李勋
发布于 2010/06/09 10:49
字数 2379
阅读 317
收藏 1

作者:终南   <li.zhongnan@hotmail.com>

 

 

 

ResultSet是使用Jdbc编程的人入门和常用的操作数据库的类,自 JDK 1.4 开始,易于使用RowSet接口被引入。RowSet 接口扩展了标准 java.sql.ResultSet 接口。RowSetMetaData 接口扩展了 java.sql.ResultSetMetaData 接口。因此,熟悉 JDBC API 的开发人员必须学习少数几个新 API 才能使用 rowset。此外,与 JDBC ResultSet 对象配套使用的第三方软件工具也可以方便地用于 rowset。但是在JDK 1.4中,只有一个RowSet接口,使得RowSet的使用范围打了折扣。不过 JDK 5.0 定义了5 个标准的 JDBC RowSet 接口,并且给出了相应的参考实现,因此可以很方便的使用RowSet接口所提供的功能。

 

RowSet 对象可以建立一个与数据源的连接并在其整个生命周期中维持该连接,在此情况下,该对象被称为连接的 rowset。rowset 还可以建立一个与数据源的连接,从其获取数据,然后关闭它。这种 rowset 被称为非连接 rowset。非连接 rowset 可以在断开时更改其数据,然后将这些更改发送回原始数据源,不过它必须重新建立连接才能完成此操作。 相比较 java.sql.ResultSet 而言,RowSet 的离线操作能够有效的利用计算机越来越充足的内存,减轻数据库服务器的负担,由于数据操作都是在内存中进行然后批量提交到数据源,灵活性和性能都有了很大的提高。RowSet 默认是一个可滚动,可更新,可序列化的结果集,而且它作为 JavaBeans,可以方便地在网络间传输,用于两端的数据同步。

 

1、与ResultSet比较

(1)RowSet扩展了ResultSet接口,因此可以像使用ResultSet一样使用RowSet。

(2)RowSet扩展了ResultSet接口,因此功能比ResultSet更多、更丰富。

(3)默认情况下,所有 RowSet 对象都是可滚动的和可更新的。而ResultSet是只能向前滚动和只读的。

(4)RowSet可以是非链接的,而ResultSet是连接的。因此利用CacheRowSet接口可以离线操作数据。

(5)RowSet接口添加了对 JavaBeans 组件模型的 JDBC API 支持。rowset 可用作可视化 Bean 开发环境中的 JavaBeans 组件。

(6)RowSet采用了新的连接数据库的方法。

(7)CacheRowSet是可以序列化的。

(8)RowSet和ResultSet都代表一行行的数据、属性以及相关操作方法。

(9)自己认为,应该倾向于把RowSet看成是与数据库无关的东西,它只是一个代表一行行数据的对象,而ResultSet则是一个与数据库紧密联系的东西。

 

2、JDK 5.0 的5个标准RowSet接口

在JDK 5.0中,5个标准RowSet接口包括 CachedRowSet,WebRowSet,FilteredRowSet,JoinRowSet 和 JdbcRowSet。相应的参考实现是Sun公司给出的,位于com.sun.rowset包下,分别为为CachedRowSetImpl,WebRowSetImpl,FilteredRowSetImpl,JoinRowSetImpl 和 JdbcRowSetImpl。这5个标准接口中JdbcRowSet是链接的rowset,而其他4个是非链接的rowset。

(1)CachedRowSet:最常用的一种 RowSet。其他三种 RowSet(WebRowSet,FilteredRowSet,JoinRowSet)都是直接或间接继承于它并进行了扩展。它提供了对数据库的离线操作,可以将数据读取到内存中进行增删改查,再同步到数据源。CachedRowSet是可滚动的、可更新的、可序列化,可作为 JavaBeans 在网络间传输。支持事件监听,分页等特性。 CachedRowSet 对象通常包含取自结果集的多个行,但是也可包含任何取自表格式文件(如电子表格)的行。

(2)WebRowSet:继承自 CachedRowSet,并可以将 WebRowSet 写到 XML 文件中,也可以用符合规范的 XML 文件来填充 WebRowSet。

(3)FilteredRowSet:通过设置 Predicate(在 javax.sql.rowset 包中),提供数据过滤的功能。可以根据不同的条件对 RowSet 中的数据进行筛选和过滤。

(4)JoinRowSet:提供类似 SQL JOIN 的功能,将不同的 RowSet 中的数据组合起来。目前在 Java 6 中只支持内联(Inner Join)。

(5)JdbcRowSet:对 ResultSet 的一个封装,使其能够作为 JavaBeans 被使用,是唯一一个保持数据库连接的 RowSet。JdbcRowSet 对象是连接的 RowSet 对象,也就是说,它必须使用启用 JDBC 技术的驱动程序(“JDBC 驱动程序”)来持续维持它与数据源的连接。

 

3、填充RowSet

前面说过,应该倾向于把RowSet看成是与数据库无关而只代表一行行数据的对象,因此就涉及到数据从哪里来的问题。

(1)从数据库直接获取数据

由于大部分情况下,与数据打交道也就是与数据库打交道,因此RowSet接口提供了通过JDBC直接从数据库获取数据的方法,以参考实现JdbcRowSetImpl为例,就是这样:

   RowSet rs = new JdbcRowSetImpl(); //也可以是CachedRowSetImpl,WebRowSetImpl,FilteredRowSetImpl,JoinRowSetImpl。
   rs.setUrl("jdbc:mysql:///test");
   rs.setUsername("root");
   rs.setPassword("");
   rs.setCommand("SELECT * FROM EMPLOYEES");
   rs.execute();

设置好相关属性,运行execute()方法后,EMPLOYEES表中的数据就被填充到rs对象中了。
除了通过设置JDBC连接URL、用户名和密码外,RowSet也可以使用数据源名称属性的值来查找已经在命名服务中注册的 DataSource 对象。完成检索后,可以使用 DataSource 对象创建到它所表示的数据源的连接,设置数据源名称可以使用setDataSourceName()方法。

(2)用ResultSet填充

在有现成ResultSet的情况下,如果想将其作为RowSet使用;或者当 DBMS 不提供对滚动和更新的完全支持时,如果想使不可滚动和只读的 ResultSet 对象变得可滚动和可更新,可以创建一个使用该 ResultSet 对象的数据所填充的 CachedRowSet 对象。

ResultSet rs = stmt.executeQuery("SELECT * FROM EMPLOYEES");
   CachedRowSet crs = new CachedRowSetImpl(); //也可以是WebRowSetImpl,FilteredRowSetImpl,JoinRowSetImpl,因为他们均继承自CachedRowSetImpl
   crs.populate(rs);

运行populate()方法后,ResultSet对象rs中的数据就被填充到crs对象中了。

(3)用XML填充

如果您打算将XML作为数据交换格式在客户端和你的服务器之间传输数据并且向实现数据离线编辑、或者向使用XML格式的数据的话,可以使用WebRowSet接口来用XML填充数据。

   WebRowSet wrs = new WebRowSetImpl();
   wrs.readXml(new FileReader(new File("D:\\employees.xml")));

运行readXml()方法后,employees.xml文件的数据就被填充到wrs对象中了。employees.xml 文件的格式参见附录。

(4)用其他方法填充

如果形用其他方式填充,比如csv、excel、text、http等格式或方法填充数据,那么就需要自己编写代码实现RowSet。

 

4、操作RowSet中的数据及元数据

除了ResultSet提供的操作数据和元数据方法外,RowSet接口没有提供太多额外的方法。

1)更新数据
   rs.absolute(5);
   rs.updateInt(1, 10);
   rs.updateInt(2, 1000);
   rs.updateString(3, "John");
   rs.updateRow();


(2)插入数据
   rs.moveToInsertRow();
   rs.updateInt(1, 10);
   rs.updateInt(2, 1000);
   rs.updateString(3, "John");
   rs.insertRow();


(3)删除数据
   rs.absolute(5);
   rs.deleteRow();


(4)设置属性
   rs.setCommand("select id, salary, name from employees where id = ?");
   rs.setInt(1, 1);
   rs.execute();


(5)元数据
   RowSetMetaData rsmd = (RowSetMetaData)rs.getMetaData();
   int count = rsmd.getColumnCount();
   int type = rsmd.getColumnType(2);
   
5、事务与更新底层数据源

RowSet本身只代表具体数据,事务以及底层数据源的更新是与底层数据源密切相关的概念。对于JDBC数据源,相应的标准接口JdbcRowSet通过与数据库相关的方法来来实现,如commit(),rollback()等。对于标准接口的中非连接rowset,如CachedRowSet,则在对RowSet中的数据改动后,通过运行acceptChanges()方法,在内部调用 RowSet 对象的 writer 将这些更改写入数据源,从而将 CachedRowSet 对象中的更改传播回底层数据源。

 

6、可序列化非连接RowSet

使用 CachedRowSet 对象的主要原因之一是要在应用程序的不同组件之间传递数据。因为 CachedRowSet 对象是可序列化的,所以可使用它(举例来说)将运行于服务器环境的企业 JavaBeans 组件执行查询的结果通过网络发送到运行于 web 浏览器的客户端。

由于 CachedRowSet 对象是非连接的,所以和具有相同数据的 ResultSet 对象相比更为简洁。因此,它特别适于向瘦客户端(如 PDA)发送数据,这种瘦客户端由于资源限制或安全考虑而不适于使用 JDBC 驱动程序。所以 CachedRowSet 对象可提供一种“获取各行”的方式而无需实现全部 JDBC API。

ebRowSet继承自CachedRowSet,除了拥有CachedRowSet的优点外,还可以将WebRowSet输出成XML,也可以将XML转换成WebRowSet,更加适合在Web环境中使用。标准的 WebRowSet XML 模式定义位于 URI http://java.sun.com/xml/ns/jdbc/webrowset.xsd。将WebRowSet保存为XML的代码事例如下:

   wrs.setCommand("select id, salary, name from employees");
   wrs.execute();  
   wrs.writeXml(new FileWriter(new File("D:\\employees.xml")));

 

附:employees.xml


http://java.sun.com/xml/ns/jdbc" xmlns:xsi=" http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation=" http://java.sun.com/xml/ns/jdbc http://java.sun.com/xml/ns/jdbc/webrowset.xsd">

    select id, salary, name from employees
    1008
   
    true
    1000
    0
    2
   
   

   
   

    0
    0
    0
    ly>true ly>
    ResultSet.TYPE_SCROLL_INSENSITIVE
    false
    employees
    jdbc:mysql:///test
   
      com.sun.rowset.providers.RIOptimisticProvider
      Sun Microsystems Inc.
      1.0
      2
      ta-source-lock>1 ta-source-lock>
   



    3
   
      1
      false
      false
      false
      0
      true
      true
      11
      id
      id
     
      11
      0
      employees
      test
      4
      INT
   

   
      2
      false
      false
      false
      1
      true
      true
      11
      salary
      salary
     
      11
      0
      employees
      test
      4
      INT
   

   
      3
      false
      false
      false
      1
      false
      true
      25
      name
      name
     
      25
      0
      employees
      test
      12
      VARCHAR
   


ta>
   
      1
      1000
      John
   

   
      2
      1200
      Tom
   

ta>

 


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/li_zhongnan/archive/2008/10/10/3049291.aspx

本文转载自:http://lixun5201612.blog.163.com/blog/static/89604840200982910534420

粉丝 4
博文 20
码字总数 0
作品 0
浦东
私信 提问
Java 6 RowSet 使用完全剖析

2008 年 6 月 05 日 C# 提供了 DataSet,可以将数据源中的数据读取到内存中,进行离线操作,然后再同步到数据源。同样,在 Java 中也提供了类似的实现,即 RowSet。DE>javax.sql.rowsetDE> ...

李勋
2010/06/09
0
0
分页查询,单sql,快速获取总行数实例

分页查询,单sql,快速获取总行数实例 注意:没有索引覆盖的情况下方法性能更高。10倍左右 使用查询时,可以通过, 使用标记sql语句, 使用执行计算总行数, 使用下的方法判断,配合循环数据...

DrChenXX
2018/10/31
0
0
代码变量拆分大SQL

关于xxx的慢查改进建议: 1、注意不要使用 *,查表时应具体指明列名 2、避免使用子查询 3、联表/分步查询时,先将范围缩小 4、可以在应用内存中完成的运算,不要交给数据库 这是两个比较急需...

青春掌柜
2017/06/19
0
0
JAVA基础--JDBC

一、JDBC 一、JDBC概述 JDBC和ODBC都基于一个思想:根据API编写的程序都可以与驱动管理器进行通信,而驱动管理器则通过驱动程序和实际的数据库进行通信。 在三层应用模式中,客户端不直接调用...

cnslp
2017/05/13
0
0
Using OLE DB Consumer Templates

Using OLE DB Consumer Templates Using UDL. 1 Connecting To The Database. 2 Retrieving Database Schema. 2 Reading Data. 3 Opening Dataset4 Retrieving Column Info. 4 Retrieving Ro......

长平狐
2012/08/28
239
1

没有更多内容

加载失败,请刷新页面

加载更多

Hadoop集群搭建-05安装配置YARN

Hadoop集群搭建-04安装配置HDFS Hadoop集群搭建-03编译安装hadoop Hadoop集群搭建-02安装配置Zookeeper Hadoop集群搭建-01前期准备 先保证集群5台虚拟机, nn1 nn2 s1 s2 s3 hadoop 是 是 是 ...

虚拟世界的懒猫
44分钟前
5
0
聊聊spring cloud的ConsulServiceRegistry

序 本文主要研究一下spring cloud的ConsulServiceRegistry ServiceRegistry spring-cloud-commons-2.1.2.RELEASE-sources.jar!/org/springframework/cloud/client/serviceregistry/ServiceR......

go4it
昨天
5
0
Nextjs 学习 —— hooks

22

lemos
昨天
2
0
如何在spring mvc restful接口中定制化类型转换和格式化

1.痛点 最近小胖哥搞了个小程序,有几个spring mvc 接口传递了时间,时间用java 8 time 相关的api 来直接接收: 当使用根据ISO 8601格式化的参数向任何这些方法发送POST请求时,报出了如下异...

码农小胖哥
昨天
17
0
docker日志监控

日志处理机制 我们先来了解一下docker日志处理的机制,当启动一个容器的时候,它其实是docker daemon的一个子进程,docker daemon可以拿到你容器里面进程的标准输出,拿到标准输出后,它会通...

爱宝贝丶
昨天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部