内容简介:当使用各种JDBC模板方法之一时,我对如何迭代/滚动大型结果集(这不适合内存)感到困惑.即使没有直接暴露的Iterable接口,我至少会期待RowCallbackHandler的实例被调用,而查询执行完成后(或堆overfloats).我确实看到了一个数据库是Oracle10g.我正在使用11.1.0.7.0生产驱动程序和Spring 2.5.6.SEC01.任何想法任何人如何迭代结果集,最好保持RowMapper的映射逻辑等?
当使用各种JDBC模板方法之一时,我对如何迭代/滚动大型结果集(这不适合内存)感到困惑.即使没有直接暴露的Iterable接口,我至少会期待RowCallbackHandler的实例被调用,而查询执行完成后(或堆overfloats).
我确实看到了一个 this (尽管在精神上相当于 this post 堆栈溢出),还有在 this 在春季论坛上的帖子.后者似乎建议在光标提取数据时确实调用回调处理程序.但是我的测试显示没有这样的行为.
数据库是Oracle10g.我正在使用11.1.0.7.0生产驱动程序和Spring 2.5.6.SEC01.任何想法任何人如何迭代结果集,最好保持RowMapper的映射逻辑等?
Oracle JDBC驱动程序对java.sql.Statement上的setFetchSize()方法有适当的支持,可以让您一次性控制驱动程序获取的行数.
然而,Spring使用的RowMapper通过将每行读入内存来获取RowMapper将其转换为对象,并将每行的对象存储在一个大列表中.如果您的结果集是巨大的,那么这个列表会变大,不管JDBC如何读取行数据.
如果需要处理大型结果集,则RowMapper不可扩展.您可以考虑使用RowCallbackHandler,以及JdbcTemplate上的相应方法. RowCallbackHandler不会决定结果的存储方式,留给您保存.
http://stackoverflow.com/questions/1341254/spring-jdbc-support-and-large-dataset
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 数据映射如何支持数据转换和数据集成?
- Vardump 更新,支持打印各种 Java 数据结构,支持嵌套
- Vardump 更新,支持打印各种 Java 数据结构,支持嵌套
- redis支持的数据结构
- Archery v1.7.9 发布,支持数据归档
- PyCharm 2018.1.1 发布,改进数据类支持
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
风云Flash ActionScript高级编程艺术
赵英杰 / 第1版 (2006年7月1日) / 2006-7 / 45.00元
本书从基本的Actionscript语言概念开始介绍,配以实际的程序实例并穿插生动的图示说明,深入浅出地讲解Flash ActionScript程序的运用逻辑与概念,让读者从实例中学习进而融会贯通。同时,本书也说明面向对象程序设计(00P)的语法及常用类别实例,提升读者制作F1ash作品的造诣和能力。全书共分为10章,精彩实例包括以三角函数制作的抽奖轮盘,FlashLite手机版孔明棋游戏,Bit......一起来看看 《风云Flash ActionScript高级编程艺术》 这本书的介绍吧!