我有:
IQueryable<Entity> query = (from e in Context.Set<TEntity>() select e);
IEnumerable<TEntity> result = query.OrderBy(x=>x.Property).Skip(10).Take(10);
OrderBy/Skip/Take 返回一个 IEnumerable<T>
.我担心会发生的情况是返回所有结果,然后使用 Linq 只取其中的一部分。
我的问题是:发出的 SQL 查询中是否包含 OrderBy/Skip 和 Take,以便仅返回总结果的请求子集?
最佳答案
The OrderBy/Skip/Take return an
IEnumerable<T>
OrderBy
has an overload that returns IOrderedQueryable<T>
,不仅IOrderedEnumerable<T>
.也是 Skip
和 Take
. C# 编译器足够聪明,优先选择这些重载而不是返回 IEnumerable<T>
的重载。 ,只要你不强制它做其他事情。该操作将在数据库中执行,只要您不将其转换为 IEnumerable
。太早了。
关于c# - EF linq skip/take 在哪里执行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26712325/