Hibernate:Query.list 与 Query.iterate 的区别

list: 结果存入缓存,但不从缓存里面取;查询时属性连同id一起找出来,只有“一句”select;
  iterate:结果存入缓存,并在缓存中查找结果;查询时先找出所有的 id,然后根据 id 到缓存里面查找,如果没有命中,再到数据库中查找该id对应的其他属性。可能会有多行 select。

分页:firstResult 与 maxResult 的影响。
Oracle:支持 rownum <= ? 的写法,因此在返回的结果集大小上对 list 和 iterate 都是一样的。但 maxResult 比较大时对使用 list 较为有利(不考虑缓存),因为 iterate 是要按 id 进行多次查找的。
    对于不支持部分结果集的数据库,必须返回所有结果(?)。这个时候,list 可能会消耗大量的内存并导致效率降低。iterate 因为只是 返回所有id,相对较好。
    不过如果是大数据量的应用,应该还是要用支持部分结果集的数据库。

如果使用二级缓存且缓存命中率较高(数据经常使用,并且较少更新),此时可以使用 iterate。

你可能感兴趣的:(oracle,Hibernate)