是否可以使用ICriteria从NHibernate查询中获取一个懒惰的IEnumerable?

The*_*edi 6 .net nhibernate .net-3.5

我正在使用NHibernate,需要检索和处理多达200万行.理想情况下,我可以处理每一行 - 一次一个 - 没有NHibernate同时加载所有200万内存(因为,你知道,这会伤害).

我更喜欢得到一个IEnumerable,它会为每次读取迭代地调用数据读取器,这样我就可以处理读取的数据 - 然后丢弃它.通过这样做,我节省了大量的内存,并开始更快地处理结果.我还可以通过多线程和/或使用PLinq来提高性能.

这可能与NHibernate的ICriteria有关吗?它返回的所有内容似乎都是IList,并在关闭集合引用之前完全加载.为什么IList而不是IEnumerable?!

我并不是说NHibernate在加载子对象或父对象时使用的传统意义上的"懒惰".我想要一个懒惰的IEnumerable意味着从ICriteria对象获取IEnumerable.ICriteria只有一个List()方法,它将结果加载到ArrayList中.

Mau*_*fer 1

ICriteria 没有任何返回 IEnumerable 的方法,但IQuery 有