MySQL における SQL ページングクエリのいくつかの実装方法と利点と欠点

MySQL における SQL ページングクエリのいくつかの実装方法と利点と欠点

【SQL】SQLページングクエリの概要

開発プロセスではページングが必要になることがよくあります。今日はここでそれをまとめてみましょう。

簡単に言えば、ソースで制御する方法と、末端で制御する方法の 2 つの方法があります。ソース コントロールはページング ロジックを SQL レイヤーに配置します。クライアント コントロールはすべてのデータを一度に取得し、ページング ロジックを UI (GridView など) に配置します。当然のことながら、オンエンド制御は開発難易度が低く、小規模データに適していますが、データ量が増加するとパフォーマンスとIO消費が許容できなくなります。オンソース制御は、パフォーマンスと開発難易度の点でよりバランスが取れており、ほとんどのビジネスシナリオに適しています。さらに、客観的な条件(パフォーマンス要件、ソースとエンドのリソース使用量など)に基づいて、ソースとエンドの間にレイヤーを追加し、処理に特別なアルゴリズムとテクノロジーを使用することもできます。以下では主にソース、つまり SQL のページングについて説明します。

ページングの問題は、実際には、条件を満たす順序付けられたデータの山から、現在表示する必要がある部分を傍受することです。実際、MySql の LIMIT、Oracle の ROWNUM と ROW_NUMBER()、SqlServer の TOP と ROW_NUMBER() など、さまざまなデータベースにはページングの問題に対する組み込み戦略があります。これに基づいて、一連のページング メソッドを取得できます。

1. MySQL の LIMIT と Oracle の ROWNUM に基づいて、戻り値の範囲を直接制限できます (MySQL を例にとると、Oracle の ROWNUM を使用する場合はサブクエリを適用する必要があることに注意してください)。

方法1: 戻り値の範囲を直接制限する

SELECT * FROM テーブル WHERE クエリ条件 ORDER BY ソート条件 LIMIT ((ページ番号 - 1) * ページ サイズ), ページ サイズ;

利点: 書き方がシンプル。
デメリット: ページ数とページ サイズが大きすぎると、パフォーマンスが大幅に低下します。
該当: データ量が多くない。

2. LIMIT (MySql)、ROWNUM (Oracle)、および TOP (SqlServer) に基づいて、返される行数を制限できるため、次の 2 つの一般的なメソッド セットを取得できます (SqlServer を例に挙げます)。

方法2: NOT IN

SELECT TOP ページサイズ * FROM テーブル WHERE 主キー NOT IN
(
 SELECT TOP (ページ番号 - 1) * ページサイズ 主キー FROM テーブル WHERE クエリ条件 ORDER BY ソート条件)
ORDER BY ソート条件

利点: 汎用性が高い。
デメリット: データ量が多い場合、ページが逆方向にめくられ、NOT IN のデータが多すぎるとパフォーマンスに影響します。
該当: データ量が多くない。

方法3: MAX

SELECT TOP ページ サイズ * FROM テーブル WHERE クエリ条件 AND ID >
(
 ISNULL(MAX(id),0) を選択 
 (
  SELECT TOP ((ページ番号 - 1) * ページサイズ) id FROM table WHERE クエリ条件 ORDER BY id 
 ) AS tempTable
) 
IDで並べ替え

利点: 特に ID が主キーである場合に高速です。
欠点: 適用範囲が狭く、ソート条件が単一かつ比較可能であることが必要です。
適用可能: 単純なソート (特別な場合には、処理のために類似の比較可能な値に変換することもできます)。

3. SqlServer と Oracle の ROW_NUMBER() に基づいて、返されるデータの行番号を取得できます。これに基づいて、戻り値の範囲を制限すると、次のメソッドが得られます (SqlServer を例に挙げます)。

方法4: ROW_NUMBER()

SELECT TOP page_size * から 
(
 SELECT TOP (ページ番号 * ページサイズ) ROW_NUMBER() OVER (ORDER BY ソート条件) AS RowNum, * FROM テーブル WHERE クエリ条件) AS tempTable
WHERE RowNum BETWEEN (ページ番号 - 1) * ページサイズ + 1 AND ページ番号 * ページサイズ ORDER BY RowNum

利点: データ量が多い場合、NOT IN よりも利点があります。
デメリット: データ量が少ない場合は NOT IN ほど効果的ではありません。
適用対象: ほとんどのページング クエリ要件。

上記は私の個人的な意見です。パフォーマンスの比較はオンライン情報と個人的な判断によるもので、綿密な実験は行っていません。不適切な点があればご指摘ください。

これで、MySQL でのページング クエリのいくつかの実装方法と利点と欠点に関するこの記事は終了です。MySQL でのページング クエリ方法の詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • MySQL 最適化チュートリアル: 大規模なページングクエリ
  • 数百万のデータボリュームに対する MySQL ページングクエリ方法とその最適化の提案
  • MySQL 百万レベルのデータページングクエリ最適化ソリューション
  • 数千万のデータを扱うMySQLのページングクエリのパフォーマンスを最適化する
  • Mysql 制限ページングクエリ最適化の詳細な説明
  • PHP ページングクエリ MySQL 結果の base64 処理方法の例
  • MySQL の制限使用法とページングクエリステートメントのパフォーマンス分析の詳細な説明
  • MySQL ページングクエリ最適化テクニック

<<:  JavaScript は、シンプルな虫眼鏡の最も完全なコード分析を実装します (ES5)

>>:  Centos サーバーに MySql をデプロイし、Navicat に接続するプロセスの詳細な説明

推薦する

MySQL グローバルロックとテーブルレベルロックの具体的な使用法

目次序文グローバルロックテーブルロックテーブルロックメタデータ ロック (MDL ロック)要約する参...

Docker がデータベースのデプロイに適さない 7 つの理由のまとめ

Docker は過去 2 年間で非常に人気が高まっています。開発者はすべてのアプリケーションとソフト...

MySQL データベース ターミナル - 一般的な操作コマンド コード

目次1. ユーザーを追加する2. ユーザー名とホストを変更する3. パスワードを変更する4. ユーザ...

VMware ESXi CLI の一般的なコマンドを調べる

目次【共通コマンド】 [一般的な esxi コマンドの概要] [esxcli コマンドの調査] ES...

Windows 10 Home Edition に Docker をインストールする方法

最近、プロジェクトをアップグレードするために Docker を使用しました。これまで使用したことがな...

Windows10でmysql8.0.17を置き換える詳細なチュートリアル

この記事では、Windows10でmysql8.0.17を置き換える具体的な手順を参考までに紹介しま...

Alibaba Cloud ESC に MYSQL8.0 をインストールするチュートリアル

接続ツールを開きます。私はMobaXterm_Personal_12.1を使用します(公式サイトのダ...

JavaScript配列についてさらに詳しく知るのに役立つ記事

目次1. 配列の役割: 2. 配列の定義: 1. コンストラクタを通じて配列を作成する2. リテラル...

Vueリスナーの使用例の詳細な説明

1つ目はjQueryのajaxを使用してリクエストを送信することです ユーザーが登録するときに、リス...

vue3.0 のウォッチ リスナーの例の詳細な説明

目次序文リスナーと計算プロパティの違いvue3 で watch を使用するにはどうすればいいですか?...

MySQL テーブル作成外部キー エラーの解決方法

データベーステーブルA: テーブル task_desc_tab を作成します ( id INT(11...

Reactを使用する際の7つの落とし穴のまとめ

目次1. コンポーネントの肥大化2. 状態を直接変更する3. プロパティは数値を渡す必要があるが文字...

MySQLデータベースのマスタースレーブレプリケーションと読み取り書き込み分離に関する詳細なチュートリアル

目次序文1. MySQL マスタースレーブレプリケーション1. サポートされているレプリケーションの...

ウェブフォーム送信方法の詳細な概要

まず、フォームを送信するいくつかの方法を見てみましょう。 1. <!--一般的な送信ボタン--...