【Sql Server】使用row_number over方式进行表分页,数据量达到五千多条记录后,查询变慢需要20多秒的解决方案
在SQL Server中,使用ROW_NUMBER()
函数结合OVER()
子句可以实现表的分页功能。以下是一个基于ROW_NUMBER()
进行分页的示例SQL查询:
-- 假设表名为YourTable,排序字段为YourColumn,每页显示10条记录
-- @PageNumber 是当前页码,@PageSize 是每页显示的记录数
DECLARE @PageNumber INT = 1;
DECLARE @PageSize INT = 10;
WITH RankedItems AS (
SELECT
*,
ROW_NUMBER() OVER (ORDER BY YourColumn) AS RowNum
FROM
YourTable
)
SELECT
*
FROM
RankedItems
WHERE
RowNum BETWEEN ((@PageNumber - 1) * @PageSize + 1) AND (@PageNumber * @PageSize);
在这个查询中,ROW_NUMBER()
会为结果集中的每一行分配一个唯一的序号,OVER()
子句里的ORDER BY
定义了序号的排列顺序。WITH
子句用于创建一个临时表,其中包含了原始表的所有行和它们的行号。外层查询利用行号来选取特定页的记录。
当数据量达到五千多条记录时,上述查询仍然有效。分页查询通过限制行号的范围来避免加载整个数据集到内存中,因此对于大数据量的分页是有效的。
评论已关闭