1. ホーム
  2. sql

[解決済み] SQL Serverで結果をページ分割する最も良い方法は何ですか?

2022-03-18 17:59:18

質問

SQL Server 2000, 2005, 2008, 2012で、結果の総数(ページ分割前)も取得したい場合、(パフォーマンス的に)最良の方法は何でしょうか?

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

結果の総数を取得することと、ページングを行うことは、異なる操作です。この例では、扱うクエリーを次のように仮定します。

SELECT * FROM Orders WHERE OrderDate >= '1980-01-01' ORDER BY OrderDate

この場合、結果の総数を決定するには、以下を使用します。

SELECT COUNT(*) FROM Orders WHERE OrderDate >= '1980-01-01'

...これは非効率に見えるかもしれませんが、すべてのインデックスなどが適切に設定されていると仮定すれば、実際にはかなり高いパフォーマンスです。

次に、実際の結果をページングで返すには、次のようなクエリが最も効率的です。

SELECT  *
FROM    ( SELECT    ROW_NUMBER() OVER ( ORDER BY OrderDate ) AS RowNum, *
          FROM      Orders
          WHERE     OrderDate >= '1980-01-01'
        ) AS RowConstrainedResult
WHERE   RowNum >= 1
    AND RowNum < 20
ORDER BY RowNum

これは、元のクエリの1-19行目を返します。ここでのクールな点は、特にウェブアプリケーションの場合、返される行番号以外の状態を保持する必要がないことです。