使用LINQ to SQL获得分页结果的最佳模式是什么?
我有以下情况:
假设我想按description搜索items表。我可以轻松做到:
public IQueryable<Item> FindItemsByDescription(string description)
{
return from item in _dc.Items
where item.Description.Contains(description);
}
现在,对这个结果集进行分页的最佳方法是什么?
- 我是否应该在执行此操作之前执行计数查询以找出结果集大小,然后根据我想要的限制此查询?我觉得这是要走的路。
- 我是否应该执行完整的查询,从数组大小中获取计数并只返回这个数组的分页子集?如果结果集足够大,我觉得这将浪费大量时间......或者LINQ to SQL在这里做了什么魔术?
是否有用于执行此操作的LINQ to SQL通用模式?
编辑:我必须澄清一件小事。我知道 Take 和 Skip 方法。但是,在使用Take和Skip之前,我应该如何获得查询将检索的结果总数?