MySQL ページングクエリ最適化テクニック

MySQL ページングクエリ最適化テクニック

ページング クエリを使用するアプリケーションでは、LIMIT と OFFSET を含むクエリが非常に一般的であり、そのほとんどすべてに ORDER BY 句が含まれます。インデックス ソートを使用すると、パフォーマンスの最適化に非常に役立ちます。そうでない場合、サーバーは大量のファイル ソートを実行する必要があります。

よくある問題は、オフセット値が大きすぎることです。クエリが LIMIT 10000、20、10020 行が生成され、前の 10000 行は破棄されるため、コストが非常に高くなります。すべてのページが同じ頻度でアクセスされると仮定すると、このようなクエリは平均してテーブルの半分をスキャンします。最適化するには、ページ分割されたビューでアクセスできるページの最大数を制限したり、大規模でコストの低いクエリをより効率的にしたりできます。

パフォーマンスを向上させる簡単な方法は、行全体ではなくカバーインデックスに対してクエリを実行することです。結果を完全な行と結合し、必要な追加の列を取得できます。これは、たとえば次のクエリのように、より効率的になります。

SELECT film_id, description FROM sakila.film ORDER BY title LIMIT 50, 5;

データ テーブルが大きい場合は、次のように最適化できます。

film.film_id、film.descriptionを選択します。
sakila.filmより
	内部結合(
    sakila.film から film_id を選択
    タイトルで注文 制限 50, 5)
  ) を lim USING(film_id); として使います。

この「推論された結合クエリ」は、インデックスを使用してサーバーがデータを確認するためにアクセスする行数を減らすため、効果的に機能します。レビューに必要な行が見つかったら、それらの行は対応するデータ テーブルの行と結合され、対応する行の他の列が取得されます。

場合によっては、制限を固定位置クエリに変換することもできます。これは、インデックスの範囲スキャンによって完了できます。たとえば、position という固定位置の列を事前計算する場合、クエリを次のように書き換えることができます。

sakila.film から film_id、description を選択
WHERE 位置が 50 から 54 の間である場合、ORDER BY 位置;

ソートされたデータも同様の方法で処理できますが、通常は GROUP BY 操作の影響を受けます。ほとんどの場合、ソート値は事前に計算して保存する必要があります。

LIMIT と OFFSET の本当の問題は OFFSET であり、これはサーバーが多くの行を破棄することを意味します。順序付けされたブックマークを使用して、取得する次の行の位置を記録すると、最後の位置から次のデータにアクセスできます。たとえば、最新のレンタル レコードから開始して逆方向に作業しながらレンタル レコードをページ分割する必要がある場合、レコードの主キーは常に増加するという事実に頼ることができるため、次のようにデータの最初のページをクエリできます。

sakila.rentalから*を選択
rental_id で並べ替え、DESC LIMIT 20 を指定します。

このクエリは 16049 から 16030 までのデータを返します。次のクエリは、前のクエリが終了したところから開始できます。

sakila.rentalから*を選択
レンタルID < 16030 
rental_id で並べ替え、DESC LIMIT 20 を指定します。

このトリックは、クエリを開始するオフセットがどれだけ離れていても機能します。

その他の手法としては、事前に計算された統計情報の使用や、冗長な主キーとソート列を持つテーブルを結合してクエリを実行することなどが挙げられます。どちらも、スペースを時間と交換することでクエリの効率を向上させます。

上記は、MySQL ページングクエリの最適化手法の詳細です。MySQL ページングクエリの最適化の詳細については、123WORDPRESS.COM の他の関連記事に注目してください。

以下もご興味があるかもしれません:
  • 数百万のデータに対するMySQLラージページクエリ最適化の実装
  • MySQLでページングクエリを実装する方法
  • 複数の無関係なテーブルからデータをクエリし、MySQL でページングする方法
  • MySQLクエリのソートとページング関連
  • MySQL 最適化チュートリアル: 大規模なページングクエリ
  • MySQLを使用してページングクエリを実装する方法

<<:  デザイン理論: なぜ私たちは間違った場所を見ているのでしょうか?

>>:  Docker ネットワークの原理とカスタム ネットワークの詳細な分析

推薦する

jQuery エディタ プラグイン tinyMCE の使い方

簡略化されたファイル サイズを変更し、サンプルをダウンロードします。ファイルをローカル コンピュータ...

MySQL マルチインスタンス構成のアプリケーションシナリオ

目次MySQL 複数インスタンスマルチインスタンスの概要マルチインスタンスとは何ですか?複数のインス...

Linux システムでデプロイメント プロジェクトを設定する方法

1. ファイアウォールの設定を変更し、対応するポートを開きますLinux システムのファイアウォール...

VirtualBox で作成された Debian 仮想マシンは Windows ホストとファイルを共有します

用語: 1. VM: 仮想マシンステップ: 1. Windows 10 に VirtualBox 6...

Docker を使用して pypi プライベート リポジトリを構築する方法

1. 建設1. htpasswd.txtファイルを準備するファイルには、パッケージを倉庫にアップロー...

Linux のファイル権限とグループ変更コマンドの詳細な説明

Linux では、すべてがファイルであり (ディレクトリもファイルです)、各ファイルにはユーザーに対...

ウェブページサイズに関する調査

<br />統計によると、Web ページの平均サイズは 2003 年以降 3 倍に増加し...

CentOS の Nginx 公式 Yum ソースの設定を詳しく解説

私はプロジェクトの展開にAlibaba Cloudから購入したCentOSを使用しています。最近、プ...

Centos8で静的IPを設定する方法の詳細な説明

CentOS 8をインストールした後、ネットワークを再起動すると次のエラーが表示されますエラーメッセ...

Vue の 4 つのカスタム命令の説明と使用例

4つの実用的なVueカスタム指示1. Vドラッグ要件: マウスドラッグ要素アイデア:要素のオフセット...

docker-compsoe を使用してフロントエンドとバックエンドを分離したプロジェクトをデプロイする方法

事前に言っておくDocker を使用すると非常にシンプルなデプロイメント環境を実現できることは誰もが...

フィルターと固定間の競合の原因と解決策の詳細な説明

問題の説明body内でfilter属性を使用すると、 fixed要素の位置が不正確になります。つまり...

Linux クラウド サーバー上に SFTP サーバーとイメージ サーバーを構築する方法

まず、SFTP プロトコルと FTP プロトコルの違いを理解してください。ここでは詳細には触れません...

時間を節約できる Linux コマンド エイリアス 15 個

序文Linux システムの管理と保守のプロセスでは、多数のコマンドが使用されます。非常に長いコマンド...

フォームにファイルをアップロードした後にアクションを保存するよう促す理由と解決策

jsonデータはhtml形式で返される必要がありますつまり、 response.setContent...