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条记录甚至更多,这是非常糟糕的解决方案.那么最好的解决方案是什么? 解决方法
这是最好的解决方案.
你是对的,如果以这种方式实施,那将是一个非常糟糕的解决方案.幸运的是,它没有以这种方式实现:Skip和Take的值以特定于SQL方言的方式传递给您的RDBMS服务器,此时数据库决定如何查找和为您提供记录.对于SQL Server,使用与此类似的语法: SELECT ... FROM ... WHERE ... ... OFFSET <skip-value> ROWS FETCH NEXT <take-value> ROWS ONLY; (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |