gpt4 book ai didi

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

转载 作者:太空宇宙 更新时间:2023-11-03 19:06:24 25 4
gpt4 key购买 nike

我有:

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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com