MySQLカバーインデックスの使用例

MySQLカバーインデックスの使用例

カバーインデックスとは何ですか?

クエリで使用されるすべてのフィールドを含むインデックスを作成することを、カバーリング インデックスと呼びます。

カバーリング インデックスを使用すると、MySQL はインデックスを使用してデータを処理した後にテーブルを返す操作を実行する必要がなく、クエリに必要なデータを検索して返すためにインデックスを使用するだけで済みます。

カバーインデックスを使用すると、クエリ作業を一度に完了できるため、IO が効果的に削減され、クエリの効率が向上します。

使用例

クエリステートメント:

test_table から col2、col3 を選択し、col1 = xxx で col2 を ORDER BY します。

単一列のインデックスを作成します。

ALTER TABLE `test_table` に BTREE を使用して INDEX `idx_col1`(`col1`) を追加します。

分析クエリ:

EXPLAIN SELECT SQL_NO_CACHE col2, col3 FROM test_table WHERE col1 = xxx ORDER BY col2;

結果: col1 のインデックスを作成した後、タイプは ref になり、idx_col1 インデックスが使用されます。

インデックスを変更し、クエリ ステートメントに基づいて結合インデックスを作成します。

テーブル `test_table` を変更し、インデックス `idx_col1` を削除します。
ALTER TABLE `test_table` ADD INDEX `idx_col1_col2_col3`(`col1`, `col2`, `col3`) USING BTREE;

分析クエリ:

EXPLAIN SELECT SQL_NO_CACHE col2, col3 FROM test_table WHERE col1 = xxx ORDER BY col2;

結果: 結合インデックスが作成されると、type は ref、idx_col1_col2_col3 インデックスが使用され、Extra は Using index となり、カバー インデックスが使用されていることが示されます。

MySQLのカバーインデックスとジョイントインデックスの違い

カバーリング インデックスとは、主キー リストの列のみをクエリするなど、クエリ対象の列をインデックスを通じて直接抽出できることを意味します。または、結合インデックスのすべての列、または左から始まるいくつかの列をクエリします (順序どおりであることに注意してください)。

結合インデックスは必ずしもインデックスからすべてのデータを取得するわけではありません。これはクエリする列によって異なります。たとえば、select * from table where ××××××; という方法は、カバーリングインデックスになる可能性は低いです。したがって、クエリする列で結合インデックスを使用でき、クエリする列を結合インデックスを通じて取得できる場合、たとえば、結合インデックスが配置されている列のみ、または左から始まる列の一部のみをクエリする場合、これはカバーリング インデックスと同等です。通常、クエリがカバーリング インデックスを使用できるようにするには、クエリ対象のデータの複数の列を結合インデックスとして設定します。

要約する

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

以下もご興味があるかもしれません:
  • MySQLはカバーインデックスを使用してテーブルリターンを回避し、クエリを最適化します。
  • MySQLのカバーインデックスに関する知識ポイントのまとめ
  • インデックスとテーブルリターンをカバーするMySQLの使い方
  • MySQLカバーインデックスの詳しい説明
  • MySQL パフォーマンス最適化の事例 - インデックス共有のカバー
  • MySQL パフォーマンス最適化のケーススタディ - インデックスと SQL_NO_CACHE をカバー
  • MySQLカバーインデックスの利点

<<:  Kylin V10 サーバーで Storm をコンパイルしてインストールする詳細なプロセス

>>:  tdが空の場合に境界線を表示する方法

推薦する

メッセージボードにメッセージを追加および削除するための JavaScript

この記事では、JavaScript メッセージ ボードでメッセージを追加および削除する小さな例を詳細...

DockerコンテナのIPアドレスを表示する方法

私はずっとDockerにはIPアドレスがないと思っていました。実はDockerのネットワークテンプレ...

ウェブサイトデザインにおいて非常に重要な概念であるdiv+floatの分析

ウェブサイトの構築では、HTML と CSS に関するさまざまな問題に常に遭遇します。ウェブサイト ...

Linux 7.6 バイナリに MySQL 8.0.27 をインストールする詳細な手順

目次1. 環境整備1.1 オペレーティング システムのバージョン1.2 ディスク容量1.3 ファイア...

HTML img タグの alt 属性と title 属性の使い方の紹介

ブラウザベンダーが標準を曲げて、ルールに従わないことをすると、問題や少なくとも混乱が生じる可能性があ...

MySQL データベース シェル import_table データ インポート

目次MySQL Shell import_table データのインポート1. import_tabl...

MySQL における大規模オブジェクトのマルチバージョン同時実行制御の詳細な説明

MySQL 8.0: InnoDB のラージ オブジェクトに対する MVCCこの記事では、MySQL...

display または visibility を通じて HTML 要素を表示または非表示にする

場合によっては、特定の条件に基づいて Web ページ内の HTML 要素を表示するか非表示にするかを...

XHTML と CSS によるオブジェクト指向プログラミング

<br />XHTML と CSS がオブジェクト指向だったらよかったのに。 。太陽は北...

mysql-8.0.19-winx64 をインストールしてログインするための初心者向けチュートリアル (初心者必読)

目次1. インストールパッケージ(64ビット)をダウンロードする2. MySQLデータベースをインス...

MySQL 5.x 以降を使用している場合のエラー #1929 列 ''createtime'' の日付時刻値が正しくありません: '''' の簡単な解決方法

MySQL をインストールした後、テーブル データを保存および削除しようとすると、常にエラー メッセ...

MySQL の時間保持問題に関する簡単な分析

MySQL のデフォルトの時間タイプ (datetime と timestamp) の精度は秒です。...

mysql8.0.20 のデータディレクトリを移行する方法

mysql のデフォルトのストレージ ディレクトリは/var/lib/mysql/です。以下は、デフ...

Vueフロントエンドパッケージングの詳細なプロセス

目次1. パッケージ化コマンドを追加する2. パッケージ化されたコードを実行する3. パッケージ化し...

vue v-for ループ オブジェクトの属性

目次1. ループオブジェクト内の値2. ループオブジェクト3. キーと値のループ1. ループオブジェ...