Implementations of RowSet, CachedRowSet etc

做~自己de王妃 提交于 2019-11-28 07:36:10
BalusC

The implementations are JRE specific. Oracle (Sun) JRE comes with a bunch of implementations:

  • com.sun.rowset.JdbcRowSetImpl
  • com.sun.rowset.CachedRowSetImpl
  • com.sun.rowset.WebRowSetImpl
  • com.sun.rowset.FilteredRowSetImpl
  • com.sun.rowset.JoinRowSetImpl

In Java 1.6 and before, you'd need to construct them yourself:

JdbcRowSet rowSet = new JdbcRowSetImpl();
rowSet.setDataSourceName("jdbc/dbname");
// Or
rowSet.setUrl("jdbc:vendor://host:port/dbname");
rowSet.setUsername("username");
rowSet.setPassword("password");

rowSet.setCommand("SELECT id, name, value FROM tbl");
rowSet.execute();

while (rowSet.next()) {
    // ...
}

In Java 1.7 you can get them by a javax.sql.rowset factory so that you're not dependent of underlying JRE implementation and that you can finetune the implementation of choice if necessary:

RowSetFactory rowSetFactory = RowSetProvider.newFactory();
JdbcRowSet rowSet = rowSetFactory.createJdbcRowSet();
// ...

It only doesn't provide a possibility to pass a ResultSet on construction. Those implementations doesn't ship with the average JDBC driver (at least, MySQL and PostgreSQL have none). It's basically an extra (optional) layer over JDBC API as the package name prefix javax hints.

Note that if you get that far by looking into rowsets, then you might want to consider to look into an ORM instead, such as Hibernate or JPA. They provide first/second level cache possibilities.

See also:

Udo Held

The RowSet and CachedRowSet are implemented by the JDBC drivers.

Your database provider delivers the drivers e.g. Oracle or MySql. However those drivers only make sense in conjunction with an actual database.

It comes with the JDK.

In JDK 10, the jar is: jdk-10.0.2/lib/jrt-fs.jar

And the package/class inside the jar is: javax.sql.RowSet.class

Daniel Pinheiro

danielpm1982@gmail.com

Add rt.jar in Eclipse Java Build Path. Then you see all the implemention class. Else you can remove the restriction from Eclipse which is not allowing to access rt.jar from jdk. Works for me. I was using jdk1.6 and Eclipse Luna.

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!