1. ホーム
  2. sql

[解決済み] SQL Server の行オフセット

2022-06-02 20:58:14

質問

SQL Server で、指定されたオフセットから始まる結果を取得する方法はありますか? 例えば、別の種類のSQLデータベースでは、可能です。

SELECT * FROM MyTable OFFSET 50 LIMIT 25

を使用して、結果51-75を取得します。この構成はSQL Serverには存在しないようです。

気にしない行をすべてロードすることなく、これを達成するにはどうしたらよいでしょうか。 ありがとうございます。

どのように解決するのですか?

私なら SELECT * . 全てでなくてもいいので、実際に必要な列を指定してください。

SQL Server 2005+

SELECT col1, col2 
FROM (
    SELECT col1, col2, ROW_NUMBER() OVER (ORDER BY ID) AS RowNum
    FROM MyTable
) AS MyDerivedTable
WHERE MyDerivedTable.RowNum BETWEEN @startRow AND @endRow

SQL Server 2000

SQL Server 2000 における大規模な結果セットの効率的なページング

大きな結果セットを通してより効率的なページングを行うための方法