entityframework lamda 使用where时的注意事项

我在项目中做了个底层 访问数据库泛型类

 BaseEFDao<T>

在获取实体模型的时候使用了

Entities.CreateObjectSet<T>().Where(Func<T,bool> 你懂的) 的方法

后来经过使用发现这是一种极其不科学的使用方法。

检测他的执行的sql语句的时候发现 居然是获取了这个表里面的所有的数据然后在程序中使用类似于linq to object的方式执行where 

如果表里面的数据量少的话 当然不会发现有什么影响,但是对于大数据量的表就会抛出内存溢出异常

我暂时找到的方法是 对于 大数据的表特殊处理 

if(typeof(T)=="大数据的表")

{

  Entities.大数据的表.Where(expression)

}

即可

总结起来还是使用.CreateObjectSet<T>()的时候出现的异常

参考 :

linq to sql中慎用Where<T>(Func<TSource, bool> predicate),小心被Linq给"骗"了!

http://www.360doc.com/content/13/0522/14/432969_287259702.shtml

如果大神有更好的解决办法 还请赐教

原文地址:https://www.cnblogs.com/yahue/p/3342695.html