加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – LINQ to Entities Skip and Take

发布时间:2020-12-15 22:16:26 所属栏目:百科 来源:网络整理
导读:我正在创建具有分页的页面,并且获取了带有参数页面和numberOfElementsPerPage的方法. 在这个方法中我使用Linq to Entities来加载页面的元素: public ListItem GetElements(int page,int numberOfElementsPerPage){ return DataContext.Items.OrderBy(x = x.
我正在创建具有分页的页面,并且获取了带有参数页面和numberOfElementsPerPage的方法.

在这个方法中我使用Linq to Entities来加载页面的元素:

public List<Item> GetElements(int page,int numberOfElementsPerPage)
{
    return DataContext.Items.OrderBy(x => x.Id).Skip((page-1)*numberOfElementsPerPage).Take(numberOfElementsPerPage);
}

我想问一下,这个Skip / Take是如何工作的?它是否首先从数据库,订单和Skip / Take获取所有记录?如果是,我认为如果数据库获得100000条记录甚至更多,这是非常糟糕的解决方案.那么最好的解决方案是什么?

解决方法

So whats the best solution?

这是最好的解决方案.

If yes I think this is pretty bad solution

你是对的,如果以这种方式实施,那将是一个非常糟糕的解决方案.幸运的是,它没有以这种方式实现:Skip和Take的值以特定于SQL方言的方式传递给您的RDBMS服务器,此时数据库决定如何查找和为您提供记录.对于SQL Server,使用与此类似的语法:

SELECT ...
FROM ...
WHERE ...
...
OFFSET <skip-value> ROWS
FETCH NEXT <take-value> ROWS ONLY;

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读