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

xiaoxiao2022-06-12  33

list: 结果存入缓存,但不从缓存里面取;查询时属性连同id一起找出来,只有“一句”select; iterate:结果存入缓存,并在缓存中查找结果;查询时先找出所有的 id,然后根据 id 到缓存里面查找,如果没有命中,再到数据库中查找该id对应的其他属性。可能会有多行 select。 分页:firstResult 与 maxResult 的影响。 Oracle:支持 rownum <= ? 的写法,因此在返回的结果集大小上对 list 和 iterate 都是一样的。但 maxResult 比较大时对使用 list 较为有利(不考虑缓存),因为 iterate 是要按 id 进行多次查找的。 对于不支持部分结果集的数据库,必须返回所有结果(?)。这个时候,list 可能会消耗大量的内存并导致效率降低。iterate 因为只是 返回所有id,相对较好。 不过如果是大数据量的应用,应该还是要用支持部分结果集的数据库。 如果使用二级缓存且缓存命中率较高(数据经常使用,并且较少更新),此时可以使用 iterate。
转载请注明原文地址: https://www.6miu.com/read-4933233.html

最新回复(0)