IQueryable,IEnumerable,List

1.IQueryable和IEnumerable都是延时执行(Deferred Execution)的,而IList是即时执行(Eager Execution)
2.IQueryable和IEnumerable在每次执行时都必须连接数据库读取,而IList读取一次后,以后各次都不需连接数据库。前两者很容易造成重复读取,性能低下,并且可能引发数据不一致性
3.IQueryable和IEnumerable的区别:IEnumberalb使用的是LINQ to Object方式,它会将AsEnumerable()时对应的所有记录都先加载到内存,然后在此基础上再执行后来的Query。所以上述TestIEnumerable例子中执行的SQL是"select top(5) ...",然后在内存中选择前两条记录返回。


example:(model1为iqeuryble或ienumerable或list)
     model      model1 = model.where(...)  model2 = model1.where(..)
IQueryble返回是是委托  延迟会推迟到最后 即 循环获取每个model2里的元素时读到内存

IEnumerable返回的是委托  但仅截止到该返回值 即  model2时读到内存

list 返回的是内存里的值,不延迟 

你可能感兴趣的:(IEnumerable,IQueryable)