Hibernate数据批量查询

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

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

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

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

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

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值