c# - EF linq skip/take 在哪里执行?

标签 c# linq entity-framework

我有:

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/

相关文章:

c# - 使用 backgroundWorker 下载文件

c# - 如何在数据库值之后等待然后继续

entity-framework - EntityFunctions 绝对值

c# - DevExpress gridView 数据源

c# - Entity Framework .NET Core 2.0 查询在执行子查询时挂起

c# - 使 Propertygrid 在运行时显示绑定(bind)的属性符号

C# - FilesystemWatcher、MDB 文件和 MySQL

c# - 将过滤器表达式动态添加到数组

c# - LINQ - 完全外部连接

c# - 查询范围的类集合产品等