ResultSet,RowSet
获得可滚动的结果集:
Statement stat = conn.createStatement(
ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY
);
获得可更新的结果集:
Statement stat = conn.createStatement(
ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_UPDATE
);
ResultSet中的Type取值:
TYPE_FORWARD_ONLY 不可滚动
TYPE_SCROLL_INSENSITIVE 结果集可滚动,但对数据库变化不敏感
TYPE_SCROLL_SENSITIVE 结果集可滚动,但对数据库变化敏感
ResultSet中的Concurrency取值:
CONCUR_READ_ONLY 结果集不能用于更新数据库
CONCUR_UPDATEABLE 结果集可以用于更新数据库
元数据的概念
通过java.sql.DatabaseMetaData可以获取数据库结构和表的详细信息。
可滚动的结果集虽然强,但交换过程,必须始终与数据库保持连接。如果一个操作要持续很久,则占用了宝贵的数据库连接资源。这时可以考虑使用行集,即RowSet。
RowSet继承自ResultSet,但不必始终保持与数据库的连接。
bwl 注:
- rs.absolute(1),rs.first(),rs.last()需要Type为TYPE_SCROLL_INSENSITIVE或者TYPE_SCROLL_SENSITIVE,如果没有声明则会抛出异常;
- rs.next()跟Type没有关系;