jdbc的几种结果集

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没有关系;

你可能感兴趣的:(数据结构,sql,jdbc)