我在项目中做了个底层 访问数据库泛型类
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
如果大神有更好的解决办法 还请赐教