考虑这两个代码:
使用Func<T, bool>
public IQueryable<Blog> GetBlogs(Func<Blog, bool> predicate)
{
return context.Blogs.Where(predicate).AsQueryable();
}使用Expression<Func<T, bool>>
public IQueryable<Blog> GetBlogs(Expression<Func<Blog, bool>> predicate)
{
return context.Blogs.Where(predicate); // No need of AsQueryable
}因此,在第一种情况下,实体框架总是会从数据库返回所有对象,对吗?那么,调用AsQueryable有什么意义呢?反正有用吗?它类似于Expression版本吗?
发布于 2017-09-21 17:12:50
反正有用吗?
不是的。
它所做的只是欺骗该方法的调用者,因为他们认为他们有一个IQueryable,它将转换应用到数据库中的SQL运行的任何附加操作符,而实际上,您只有一个穿着羊皮的IEnumerable。如果您真的希望在内存中执行操作,而不是在DB中执行操作,那么至少要明确地将IEnumerable类型为IEnumerable。
https://stackoverflow.com/questions/46349567
复制相似问题