`
lijiejava
  • 浏览: 262870 次
  • 性别: Icon_minigender_1
  • 来自: 南通
社区版块
存档分类
最新评论

Hibernate数据批量查询

阅读更多
Hibernate中提供了两种批量查询的方法:list与iterate。 Hibernate查询接口Query,Criteria的查询功能,其内部也是基于这两个方法实现。

概述:list方法通过一条sql语句实现查询操作,而iterate方法第一次发出的sql语句获得所以符合条件的记录的id,之后,再根据各个id从库表中读取对应的记录,这是一个典型的N+1问题。

Hibernate同时提供这两种方法的原因:
(1) 在于Hibernate的缓存机制

list方法执行sql语句,从数据库中获得所有符合条件的记录并构造相应的实体对象,实体对象构建完毕之后,将其纳入缓存。这样,如果之后再执行iterate方法,它首先执行一条sql语句获得所有符合查询条件的数据id,随即,iterate方法首先在本地缓存中根据id查找对应的实体对象是否存在(类似session.load方法),如果缓存中已经存在对应的数据,则直接以此数据对象作为查询结果。如果没能找到,再执行相应的sql语句(iterate方法如果执行sql语句,获得对象后也会将其纳入缓存)。如果目标数据只读或者读取相对较为频繁,两者结合使用可大大提高性能。

(2)除此之外,还有内存使用上的考虑

假设需要对海量数据进行操作,那么list方法将一次获取所有的记录并将其读入内存。假设有10万条,可能会出现内存溢出。解决方法就是结合iterate和evict方法逐条对记录进行处理,将内存消耗保持在可接收的范围内。(iterate方法返回Iterator类型,只有调用next方法时才发出sql语句)

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics