MySQL ジョイントインデックスの使用ルール

MySQL ジョイントインデックスの使用ルール

結合指数は複合指数とも呼ばれます。複合インデックスの場合: MySQL はインデックス内のフィールドを左から右に使用します。クエリではインデックスの一部のみ、つまり左端の部分のみを使用できます。たとえば、インデックスはキーインデックス (a,b,c) です。a | a,b | a,b,c の 3 つの組み合わせの検索はサポートできますが、b,c の検索はサポートしていません。左端のフィールドが定数参照の場合、インデックスは非常に効果的です。

興味深い質問から始めましょう:

テーブルに結合インデックス (c1、c2、c3、c4) があるとします。どのフィールドがインデックスを使用しますか?
c1=x かつ c2=x かつ c4>x かつ c3=x の場合
B、c1=x、c2=x、c4=x、c3の順序
C、c1=x、c4=x の場合、c3、c2 でグループ化
D ここで c1=? かつ c5=? で c2,c3 の順
E ここで c1=? かつ c2=? かつ c5=? で c2,c3 の順序

始めましょう:

まずテーブルを作成します。

テーブルtを作成します(
c1 CHAR(1) NULLではない、
c2 CHAR(1) NULLではない、
c3 CHAR(1) NULLではない、
c4 CHAR(1) NULLではない、
c5 CHAR(1) ヌルではない
)エンジン myisam CHARSET UTF8;


c1からc5までの5つのフィールドがあります。フィールドタイプはすべて固定長char(1)型であり、空ではないことに注意してください。文字セットはutf8です(インデックスの計算に使用されるバイト数に関連します)

インデックスを作成します。

テーブル t を変更し、インデックス c1234(c1,c2,c3,c4) を追加します。

2 つのレコードを挿入します: insert into t VALUES('1','1','1','1','1'),('2','2','2','2','2','2')

MySql Explain を使用して、質問の結果の分析を開始します。

オプションA:


結果からわかるように、c1、c2、c3、c4 はすべてインデックスを使用しており、A の結果を少し変更しています。

c2 条件を削除した後:


左端のインデックス原則によれば、c2 フィールドはインデックスを使用せず、c2 より後のフィールドはインデックスを使用できません。次の 2 つの図では、左端のインデックス原理を比較しています。


上図の結果は、c3 を直接使用すると完全なテーブルクエリになり、インデックスを使用できないことを示しています。したがって、c3 フィールドにインデックスを使用する前提は、c1 フィールドと c2 フィールドの両方でインデックスが使用されていることです。

それがインデックスの一番左の原則(左接頭辞原則)です。

オプションB:


key_len の長さは、インデックスが c1 および c2 フィールドで使用されていることを示しています。Extra は、ソートに一時テーブルが使用されていないことを示しています。つまり、インデックスはソートに使用されていますが、key_len 値では計算されておらず、c4 に接続する目的には役立ちません。つまり、インデックスは c3 で壊れていることを意味します。

実際、ソートはジョイント インデックスを使用して直接実行されます。つまり、c1234 ジョイント インデックスを使用すると、c1 の下の c2、c2 の下の c3、c3 の下の c4 がすでに整列しています。したがって、ソートでは実際にはインデックスが使用されますが、c3 フィールドではインデックスは使用されません。 (この段落を書くときはいつも少しぎこちなく感じました。正しく理解しているかどうかわかりません。まださらに調査が必要です)

オプションC:


グループ化を使用する場合、通常は最初に一時ファイルが生成され、その後ソートされます。ただし、フィールド順序が c2、c3 の場合、一時テーブルはソートに使用されず、インデックスがソートに使用されます。グループ化フィールドが c3、c2 の場合、順序がインデックス フィールドの順序と一致しないため、インデックスはグループ化とソートに使用されません。

key_len の長さによって決定され、c1 フィールドのみがインデックスを使用します。

オプションD:


order by は group by に似ています。フィールドの順序がインデックスと一致している場合は、インデックスが並べ替えに使用されます。フィールドの順序がインデックスと一致していない場合は、インデックスは使用されません。

key_len の長さによって決定され、c1 フィールドのみがインデックスを使用します。

オプションE:


実際、オプション E の結果分析は、上記の ABCD の結果で分析されています。ここでは、c1 フィールドと c2 フィールドのみがこのインデックスを使用します。

上記の質問に対する答えをまとめると次のようになります。

A: 4 つのフィールドすべてがこのインデックスを使用します。

B: c1、c2フィールドはこのインデックスを使用します

C:c1フィールドはこのインデックスを使用します

D:c1フィールドはこのインデックスを使用します

E: c1 フィールドと c2 フィールドはこのインデックスを使用します。

要約:

インデックスの左端原則(左プレフィックス原則)は、(c1, c2, c3, c4....cN)の結合インデックスのように、インデックスが設定されているフィールドの順序で where 条件を使用します(and 条件を順番に記述しなければならないという意味ではありません)。途中の列に条件がない場合や like を使用した場合は、それ以降の列ではインデックスを使用できません。

インデックスはグループ化や並べ替えにも使用できます。グループ化では、まず並べ替え、次に平均の計算などが必要になります。したがって、グループ化と並べ替えでは、フィールドの順序がインデックス付きフィールドの順序に従うことができれば、インデックスの順序付けされた性質を利用できます。

MySQL ジョイントインデックスの使用ルールに関するこの記事はこれで終わりです。MySQL ジョイントインデックスに関するより関連性の高いコンテンツについては、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • MySQL 独立インデックスと共同インデックスの選択
  • MySQL ジョイントインデックス(複合インデックス)の実装
  • MySQLジョイントインデックスの左端一致原則の詳細な分析
  • MySQLのジョイントインデックス機能の分析と使用例
  • MySQL ジョイントインデックスの使用例
  • MySQL のジョイントインデックス学習チュートリアル
  • MySQL のインデックス有効条件とインデックス無効条件の結合

<<:  CSS ハック \9 と \0 は IE11\IE9\IE8 のハッキングには機能しない可能性があります

>>:  iframe パラメータの説明と例

推薦する

kindとDockerを使用してローカルKubernetes環境を起動する

導入Kubernetes を使い始めるのに丸一日を費やしたことはありませんか?最近登場したいくつかの...

WeChatアプレットがログインインターフェースを実装

WeChatアプレットのログインインターフェースは参考までに実装されています。具体的な内容は次のとお...

MySQL 分離レベルの詳細な説明と例

目次MySQL の 4 つの分離レベルデータ テーブルを作成します。分離レベルの設定物事の分離レベル...

JavaScript は単一のリンクリストプロセス分析を実装します

序文:複数の要素を格納するために、配列は最も一般的に使用されるデータ構造ですが、配列には多くの欠点も...

Vue での this.$set の動的データバインディングのケーススタディ

インターネット上の this.$set の説明はわかりにくいと感じます。単一データ、オブジェクト、配...

Zabbixで電子メールアラートを実装する方法

オンラインチュートリアルに従って実装しました。 zabbix3.4、スクリプトとsendEmailを...

Angularルーティングアニメーションと高度なアニメーション機能の詳細な説明

目次1. ルーティングアニメーション2. グループクエリとスタガー1. ルーティングアニメーションル...

エラー 1045 (28000): ユーザー ''root''@''localhost'' のアクセスが拒否されました (パスワード使用: YES) 実用的な解決策

昨日はデータベースへの接続に問題はありませんでしたが、今日はデータベースへの接続時にこのエラーが報告...

フロントエンドJavaScriptの約束

目次1. Promiseとは何か2. 基本的な使い方3. Promiseメソッド3.1 Promis...

Element UI を使用してページにページング ナビゲーション バーを追加する方法

必要ページング バーを追加します。これにより、ページにジャンプしたり、ページ番号に従って特定のページ...

win10 での mysql 8.0.16 winx64 インストールの最新グラフィック チュートリアル

このデータベースをダウンロードするには、多くの時間とトラフィックがかかります。踏み込んだ落とし穴で時...

HTMLページがincludeを使用してphpファイルをインポートした後に余分な空白行があります

インターネットで見つけた方法は効果的ですinclude によって導入されたフッター ファイルとヘッダ...

HTMLの最適化によりWebページの速度が向上

明らかな HTML、隠された「公開スクリプト」 Web ページのダウンロード時間を短縮する鍵は、フ...

nginxリバースプロキシwebSocket設定の詳細な説明

最近、プロジェクトで作業しているときに webSocket プロトコルを使用し、WeChat アプレ...

React イベントバインディングの詳細

目次クラスコンポーネントイベントバインディング関数コンポーネントイベントバインディング要約するRea...