快速业务通道

教你使用Java中的RowSet - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-14
据过滤的功能。 可以根据不同的条件对 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对象中了。

教你使用Java中的RowSet(3)

时间:2011-10-21 Java学习室 终南

(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.exec

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号