MySQL の冗長インデックスと重複インデックスの詳細な説明

MySQL の冗長インデックスと重複インデックスの詳細な説明

MySQL では、同じ列に複数のインデックスを作成できます。意図的であるかどうかにかかわらず、MySQL は重複したインデックスを個別に維持する必要があり、クエリを最適化するときにオプティマイザもそれらを 1 つずつ考慮する必要があるため、パフォーマンスに影響します。

重複インデックスとは、同じ列に同じ順序で作成された同じタイプのインデックスを指します。このように重複インデックスを作成することは避け、見つかった場合はすぐに削除する必要があります。ただし、異なるクエリ要件を満たすために、同じ列に異なるタイプのインデックスを作成することは可能です。

CREATE TABLEテスト(
 ID INT NOT NULL 主キー、
 INT NOT NULL、
 B INT NULLではない、
 ユニーク(ID)
 インデックス(ID)、
)ENGINE=InnoDB;

この SQL は 3 つの重複インデックスを作成します。通常、これを行う理由はありません。

冗長インデックスと重複インデックスにはいくつかの違いがあります。インデックス (a, b) を作成する場合、インデックス (a) の作成は、前のインデックスのプレフィックス インデックスにすぎないため冗長インデックスになります。したがって、(a, b) は (a) としても使用できますが、(b, a) は冗長インデックスではありません。また、インデックス (b) も、b がインデックス (a, b) の左端のプレフィックス列ではないため冗長インデックスではありません。さらに、同じ列に作成された他の異なるタイプのインデックス (ハッシュ インデックスやフルテキスト インデックスなど) は、カバーされるインデックス列に関係なく、B ツリー インデックスの冗長インデックスにはなりません。

冗長なインデックスは通常、テーブルに新しいインデックスを追加するときに発生します。たとえば、既存のインデックス (A) を拡張するのではなく、新しいインデックス (A,B) を追加する場合があります。もう 1 つのケースは、インデックスを (A, ID) に拡張することです。ここで、ID は主キーです。InnoDB の場合、主キーはすでにセカンダリ インデックスに含まれているため、これも冗長です。

ほとんどの場合、冗長インデックスは不要であり、新しいインデックスを作成するのではなく、既存のインデックスを拡張する必要があります。ただし、既存のインデックスを拡張するとサイズが大きくなりすぎて、そのインデックスを使用する他のクエリのパフォーマンスに影響するため、パフォーマンス上の理由から冗長インデックスが必要になる場合があります。たとえば、整数列にインデックスがあり、インデックスを拡張するために長い varchar 列を追加する必要がある場合、特にこのインデックスをカバー インデックスとして使用するクエリがある場合、またはこれが MyISAM テーブルであり、範囲クエリが多数ある場合 (MyISAM プレフィックス圧縮のため)、パフォーマンスが大幅に低下する可能性があります。

たとえば、userinfo テーブルがあります。このテーブルには 1,000,000 件のレコードがあり、state_id 値ごとに約 20,000 件のレコードがあります。 state_idにはインデックスがあるので、次のSQLはQ1と呼ばれます。

SELECT count(*) FROM userinfo WHERE state_id=5; --Q1

クエリ実行速度は1秒あたり約115回(QPS)です。

もう1つのSQLがあります。これをQ2と呼びましょう。

SELECT state_id,city,address FROM userinfo WHERE state_id=5; --Q2

このクエリの QPS は 10 です。このインデックスのパフォーマンスを向上させる最も簡単な方法は、インデックスがクエリをカバーできるように、(state_id、city、address) のワイルド ウォー インデックスを使用することです。

アラート テーブル userinfo にキー state_id_2(state_id,city,address) を追加します。

注: state_id にはすでにインデックスがあります。前の概念によれば、これは重複インデックスではなく冗長インデックスです)

冗長インデックスと重複インデックスを見つけるにはどうすればよいでしょうか?

1. Shlomi Noach の common_schema のいくつかのビューを使用して、それを見つけることができます。common_schema は、サーバーにインストールできる共通のストレージとビューのセットです。

2. Percona Toolkit の pt_duplicate-key-checker を使用すると、テーブル構造を分析して冗長なインデックスや重複したインデックスを見つけることができます。

要約する

以上が、MySQL の冗長インデックスと重複インデックスの詳細な説明に関するこの記事の内容のすべてです。皆様のお役に立てれば幸いです。興味のある方は、次のものを参照してください: いくつかの重要な MySQL 変数、Redis と MySQL の違いの簡単な説明、MYSQL サブクエリとネストされたクエリの最適化例の分析など。不足がある場合は、メッセージを残して指摘してください。編集者が適時に返信し、修正します。このサイトをサポートしていただき、ありがとうございます!

以下もご興味があるかもしれません:
  • MySQLクエリの冗長インデックスと未使用のインデックス操作
  • MySQL 重複インデックスと冗長インデックスの例の分析
  • MySQL における冗長インデックスと重複インデックスの違い

<<:  Vueはログインタイプの切り替えを実装します

>>:  VirtualBox仮想マシンがNATモードで外部ネットワークに接続できない問題の解決策

推薦する

MySQL 5.7.29 + Win64 解凍バージョンのインストールチュートリアル(画像とテキスト付き)

公式サイトをダウンロード自分に合ったバージョンを選択してダウンロードしてください。 ダウンロードをク...

Docker に ElasticSearch をインストールする方法を 1 つの記事で解説

目次序文1. Dockerをインストールする2. ElasticSearchをインストールする3. ...

Vue-Element-Adminはログインジャンプを実現するために独自のインターフェースを統合しています

1. まずリクエスト設定ファイルを見て、axios.createメソッドを見てください。baseUR...

Mac での MySQL と Squel Pro の設定

Node.js の人気に応えて、最近、いくつかのサーバー側機能を実装するために Node.js を使...

よく使うLinuxコマンドのまとめ

私は2年間運用保守に携わり、多くのコマンドを使用しました。特定のLinuxコマンドを習得すると、どれ...

カルーセル効果を作成するためのjs

カルーセルはフロントエンド開発において比較的重要なポイントだと思います。ネイティブjsの知識ポイント...

Centos7 Zabbix3.4 メールアラーム設定(メール内容がxx.bin添付ファイルになる問題の解決)

目次1. 監視Linuxホストを追加する2. メールボックスを設定する1. 監視Linuxホストを追...

Centos7 での Mysql5.7.19 の詳細なインストールチュートリアル

1. ダウンロード公式サイトからmysql-5.7.19-linux-glibc2.12-x86_6...

Apache の一般的な仮想ホスト設定方法の分析

1. Apacheサーバーのインストールと設定yum インストール httpd -y systemc...

CSS リスト モデルでのマーカー タグの使用

この記事では主に、 list-itemの下にある::master疑似要素、 list-style-i...

Baidu 入力メソッドが API を公開、自由に移植して使用できると主張

百度入力方式の担当者は、百度入力方式のオープンAPIの最大の利点は操作が便利であることであり、プラッ...

MySQLでデータベースデータ保存ディレクトリを変更する方法

序文MySQL データベースのデフォルトのデータベース ファイルは /var/lib/mysql に...

Linux (CentOS7) に Tomcat をインストールし、Tomcat をスタートアップ項目として設定します (tomcat8 を例に挙げます)

目次TomcatをインストールするTomcat 圧縮パッケージをダウンロードTomcatには3つの主...

マウスを傾けた状態でのフリップナビゲーションの問題に関する研究

この記事では、マウス フリップナビゲーションの制作についてまだ疑問を持っている友人の役に立つことを期...

CentOS 6.9 で glibc ダイナミック ライブラリをアップグレードする詳細なプロセス

glibc は、gnu によってリリースされた libc ライブラリ、つまり c ランタイム ライブ...