内容简介:当使用各种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 发布,改进数据类支持
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
浪潮之巅(第2版)(套装上下册)
吴军 / 人民邮电出版社 / 2013-7 / 80.00元
一个企业的发展与崛起,绝非只是空有领导强人即可达成。任何的决策、同期的商业环境,都在都影响着企业的兴衰。《浪潮之巅》不只是一本历史书,除了讲述科技顶尖企业的发展规律,对于华尔街如何左右科技公司,以及金融风暴对科技产业的冲击,也多有着墨。此外,这本书也着力讲述很多尚在普及或将要发生的,比如微博和云计算,以及对下一代互联网科技产业浪潮的判断和预测。因为在极度商业化的今天,科技的进步和商机是分不开的。 ......一起来看看 《浪潮之巅(第2版)(套装上下册)》 这本书的介绍吧!