第一篇:https://www.cnblogs.com/zgqys1980/p/4047315.html;
第二篇:https://www.cnblogs.com/shenbing/p/5394228.html
第三篇:https://blog.csdn.net/ydm19891101/article/details/50969323
第四篇:http://www.igiven.com/?p=2804 (这篇最好,阐释最详尽,最透彻)
下面内容摘自上面第4篇博客,非本人原创:
那么什么时候用IQueryable,什么时候用IEnumerable?
1.Func<>谓词表达式,就是一个委托,委托一旦调用,就立即执行了,将执行结果保存在内存中。
2.Expression是一个表达式,会存储拼接表达式树,直到在运行期最终执行。
那么在EF中我们根据条件查询数据时,不应该把数据一次性加载到本地内存中,然后再本地内存中进行筛选,如果数据量大了,就崩溃了。
我们需要将表达式组合好,然后再一起提交到数据库执行,返回查询结果。
(每次在执行where查询操作符的时候IQueryProvider会为我们创建一个新的IQueryable,调用AsEnumerable()方法的时候并不会去实际取值,只是
得到了一个IEnumerable,所以EF在查询数据时候不要先取IEnumerable再去筛选数据。执行ToList方法时才会去真正调用迭代器GetEnumerator()
取值。真正取值时候,会去执行IQueryProvider中的Excute方法.(解析表达式,然后执行取得结果))
这就是IQueryable的延迟加载把.
.知识点总结
(1) 解决查询多次的问题,因IQueryable延迟加载,当用到集合的时候,provider会解析表达式,然后生成查询,所以会走一个复杂的过程。
(2) 本地集合:List,Array,IEnumable都是本地集合,都是缓存在里面的
(3) 使用EF管理上下文实例的最佳选择是线程的唯一。
(4) IEnumerable接口是一个公开枚举器,该枚举器支持在指定的集合上进行简单迭代,也就是次接口可以直接使用foreach遍历次Object。