我正在使用NHibernate,需要检索和处理多达200万行.理想情况下,我可以处理每一行 - 一次一个 - 没有NHibernate同时加载所有200万内存(因为,你知道,这会伤害).
我更喜欢得到一个IEnumerable,它会为每次读取迭代地调用数据读取器,这样我就可以处理读取的数据 - 然后丢弃它.通过这样做,我节省了大量的内存,并开始更快地处理结果.我还可以通过多线程和/或使用PLinq来提高性能.
这可能与NHibernate的ICriteria有关吗?它返回的所有内容似乎都是IList,并在关闭集合引用之前完全加载.为什么IList而不是IEnumerable?!
我并不是说NHibernate在加载子对象或父对象时使用的传统意义上的"懒惰".我想要一个懒惰的IEnumerable意味着从ICriteria对象获取IEnumerable.ICriteria只有一个List()方法,它将结果加载到ArrayList中.