たとえば、テーブルに 10.000 レコードがあります。クエリを実行するたびに、ページ番号n
をパラメーターとして取得します。n
からまでのレコードを選択する必要がn*100
あり、いくつかの複雑な条件を満たす必要があります。も使用しているため、最後の要素の を保持して、主キーを使用して上位のレコードを選択ORDER BY
することはできません。どうすればこれを達成できますか?PrimaryKey
n
2 に答える
4
ページ計算に基づいて、次のクエリでFromパラメータとToパラメータの値を渡します。
WITH NumberedMyTable AS
(
SELECT
*,
ROW_NUMBER() OVER (ORDER BY Id) AS RowNumber
FROM
MyTable
)
SELECT
*
FROM
NumberedMyTable
WHERE
RowNumber BETWEEN @From AND @To
于 2012-05-15T13:20:57.510 に答える
1
declare @n int
set @n=2
with my_query as(
select ROW_NUMBER() over (order by name) as ID, *
from sys.tables
)
select *
from my_query
where ID >=@n and ID<=(@n*10)
于 2012-05-15T13:26:27.900 に答える