[解決済み] 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行目を返します。ここでのクールな点は、特にウェブアプリケーションの場合、返される行番号以外の状態を保持する必要がないことです。
関連
-
[解決済み] SQL ServerでSELECTからUPDATEする方法とは?
-
[解決済み] callとapplyの違いは何ですか?
-
[解決済み] SQLiteのINSERT/per-secondのパフォーマンスを向上させる
-
[解決済み] テーブルネーミングのジレンマ:単数形と複数形の名前【非公開
-
[解決済み] SQL Server にテーブルが存在するかどうかを確認する
-
[解決済み] SQLのIN句をパラメータ化する
-
[解決済み] SQL Server における DateTime2 と DateTime の比較
-
[解決済み】「INNER JOIN」と「OUTER JOIN」の違いは何ですか?
-
[解決済み】SQL Serverで既存のテーブルにデフォルト値を持つカラムを追加する
-
[解決済み] SQL ServerでINNER JOINを使用して削除するにはどうすればよいですか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
SQLラーニングノート--オペランドには1つのカラムが必要です。
-
[解決済み] SQLサーバーでNULL = NULLがfalseに評価される理由
-
[解決済み] SQL Server : 列を行に変換する
-
[解決済み] データベースのインデックス作成はどのように行われるのですか?[クローズド]
-
[解決済み] 各グループの上位1行を取得
-
[解決済み] SQLiteデータベースで、一度に複数行を挿入することは可能ですか?
-
[解決済み] 文字列の一部をUPDATEおよびREPLACEする。
-
[解決済み] SQL ServerでGROUP BYを使って文字列を連結する方法とは?
-
[解決済み] Entity Framework VS LINQ to SQL VS ADO.NETでストアドプロシージャを使う?[クローズド]
-
[解決済み] SQL/mysql - Select distinct/UNIQUE but return all column?