3 回答

TA貢獻1797條經(jīng)驗 獲得超6個贊
您可以嘗試類似
DECLARE @Table TABLE(
Val VARCHAR(50)
)
DECLARE @PageSize INT,
@Page INT
SELECT @PageSize = 10,
@Page = 2
;WITH PageNumbers AS(
SELECT Val,
ROW_NUMBER() OVER(ORDER BY Val) ID
FROM @Table
)
SELECT *
FROM PageNumbers
WHERE ID BETWEEN ((@Page - 1) * @PageSize + 1)
AND (@Page * @PageSize)

TA貢獻1828條經(jīng)驗 獲得超13個贊
您可以使用ROW_NUMBER():
返回結果集分區(qū)中一行的序號,從每個分區(qū)中第一行的1開始。
例:
WITH CTEResults AS
(
SELECT IDColumn, SomeField, DateField, ROW_NUMBER() OVER (ORDER BY DateField) AS RowNum
FROM MyTable
)
SELECT *
FROM CTEResults
WHERE RowNum BETWEEN 10 AND 20;
- 3 回答
- 0 關注
- 933 瀏覽
添加回答
舉報