具有大量记录的Sql Server分页

Posted

技术标签:

【中文标题】具有大量记录的Sql Server分页【英文标题】:Sql Server Pagening with large amount of records 【发布时间】:2014-08-29 12:40:56 【问题描述】:

我有这个用于分页的 SQL 查询:

SELECT * FROM 
  (
    SELECT T1.*,T2.*, ROW_NUMBER() over(ORDER BY ID DESC) row 
    FROM 
        table1 t1
         LEFT JOIN 
        table2 t2 on t1.id = t2.pid
  ) tbl
WHERE row>= @start and row<@end

现在的问题是选择结果可以是数千条记录,这些记录将针对每个用户的每个页面执行。

任何建议我可以部分选择(选择更少的记录?)

ROW_NUMBER 可能按 ID 或 DATE 排序。

顺便说一句,选择 * 只是为了简化示例代码。

【问题讨论】:

您使用的是什么版本的 SQL Server? 这些答案有帮助吗? ***.com/questions/4358253/… 【参考方案1】:

如果您有 SQL Server 2012 或更高版本,则可以使用 Offset 和 Fetch 关键字,如 here 所述

【讨论】:

如他没有写在 cmets 中的那样;) 好吧,我也许可以使用sql server 2012,性能是我的首要任务

以上是关于具有大量记录的Sql Server分页的主要内容,如果未能解决你的问题,请参考以下文章

骨干.js分页

Laravel 多页分页

单页分页问题中的多个角度材料表

react-slick 自定义分页分页道具使用

梦内容页分页标题提取

一个视图中的 CI 多页分页,