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 ネットワークの原理とカスタム ネットワークの詳細な分析

推薦する

MySQL ルートパスワードを変更する 4 つの方法 (要約)

方法1: SET PASSWORDコマンドを使用するまずMySQLにログインします。フォーマット: ...

CSSレイアウトで中央揃えレイアウトを実現する方法

1. 親コンテナーをテーブルに設定し、子をインライン要素に設定します。テキストを表示するサブコンテン...

HTMLタグのtarget属性の使用法

1: <a> タグを使用してページにリンクする場合、target 属性の役割は誰もが知っ...

NexusはAPIを使用して操作します

Nexus は RestApi を提供していますが、一部の API はまだ Groovy と組み合わ...

Linux のリンク解除機能とファイルの削除方法

1. リンク解除機能ハード リンクの場合、unlink はディレクトリ エントリを削除し、inode...

echarts ワードクラウドチャートを使用した Vue の実践記録

echartsワードクラウドはechartsの拡張版ですhttps://echarts.apache...

Vue nextTickの原理の分析

目次イベントループmiscroTask (マイクロタスク) UI レンダリング (重要なポイント)次...

単一のMySQLテーブルを復元する手順

休憩中に、眠気を完全に吹き飛ばす電話がかかってきました。「開発者が更新 SQL を書くときに whe...

Dockerを使用してブログサイトを素早く構築する方法の詳細な説明

目次1. 準備2. 展開プロセス3. アクセステストHalo は、ブログに慣れている学生に追加のオプ...

ネイティブJSが様々なスポーツの均一な動きを実現

この記事では、ネイティブ JS で実装された均一なモーションを紹介します。その効果は次のとおりです。...

nginx をコンパイルしてインストールした後、スムーズに nginx をアップグレードする方法

nginx をコンパイルしてインストールし、一定期間使用した後、現在のバージョンに脆弱性があることや...

CSS シャドウアニメーションの最適化のヒント

このテクニックは、この記事から来ています - シルキーでスムーズなパフォーマンスでボックスシャドウを...

進捗バー効果を実現するJavaScript

この記事では、プログレスバー効果を実現するためのJavaScriptの具体的なコードを参考までに紹介...

Vueでファジークエリを実装する方法の簡単な例

序文いわゆるファジークエリとは、ユーザーの完全な入力やすべての入力情報がなくてもクエリサービスを提供...

CentOS7 環境で gcc (バージョン 10.2.0) をアップグレードする詳細な手順

目次簡単な紹介1. 現在のgccバージョンを確認する2. gccインストールパッケージ(バージョン1...