热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

JDBC读取大量数据时的ResultSetresultSetType设置TYPE_FORWARD_ONLY

在创建PreparedStatement时,resultSetType参数设置的是TYPE_SCROLL_INSENSITIVE或TYPE_SCROLL_SENSITIVE,这两个

在创建PreparedStatement时,resultSetType参数设置的是TYPE_SCROLL_INSENSITIVE或TYPE_SCROLL_SENSITIVE, 
这两个参数的共同特点是允许结果集(ResultSet)的游标可以上下移动。而默认的TYPE_FORWARD_ONLY参数只允许结果集的游标向下移动。

如果PreparedStatement对象初始化时resultSetType参数设置为TYPE_FORWARD_ONLY,在从ResultSet(结果集)中读取记录的时,对于访问过的记录就自动释放了内存。而设置为TYPE_SCROLL_INSENSITIVE或TYPE_SCROLL_SENSITIVE时为了保证能游标能向上移动到任意位置,已经访问过的所有都保留在内存中不能释放。所以大量数据加载的时候,就OOM了。
 

statement = conn.prepareStatement(querySql,ResultSet.TYPE_FORWARD_ONLY,ResultSet.CONCUR_READ_ONLY);

resultSetType是设置ResultSet对象的类型标示可滚动,或者是不可滚动。取值如下:

 

 ResultSet.TYPE_FORWARD_ONLY

只能向前滚动(这是默认值)
 

     ResultSet.TYPE_SCROLL_INSENSITIVE

 

这两个方法都能够实现任意的前后滚动,使用各种移动的ResultSet指针的方法。二者的区别在于前者对于修改不敏感,而后者对于修改敏感。

 

 

 Result.TYPE_SCROLL_SENSITIVE

 

resultSetConcurency是设置ResultSet对象能够修改的,取值如下:

 

ResultSet.CONCUR_READ_ONLY

 

设置为只读类型的参数。

ResultSet.CONCUR_UPDATABLE

 

设置为可修改类型的参数。


推荐阅读
author-avatar
税绍彬_396
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有