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モードで外部ネットワークに接続できない問題の解決策

推薦する

5分でDockerを使ってRedisのクラスターモードとセンチネルモードを構築する方法を教えます

目次1. 準備Redisイメージを取得する2. Redis Sentinel マスタースレーブモード...

MACOS で MySQL ルートパスワードを忘れた場合の解決策

MySQL は、スウェーデンの会社 MySQL AB によって開発されたリレーショナル データベース...

Vue ドラッグ アンド ドロップのシンプルな実装

この記事では、主に次のような Vue ドラッグ アンド ドロップの簡単な実装を紹介します。レンダリン...

MySQL は対応するクライアント プロセスにどのように接続しますか?

質問特定の MySQL 接続について、それがどのクライアント プロセスからのものであるかをどのように...

仮想マシンUbuntu 16.04がインターネットに接続できない問題の解決策

Ubuntu をインストールしたばかりですが、開いたときにネットワーク接続がありませんでした。右上隅...

JavaScript 中断要求に対するいくつかの解決策の詳細な説明

目次1 約束呼び出しチェーンを中断する約束を破る中止メソッドのラッピング - Axios の Can...

Vue.js フロントエンド Web ページ ポップアップ非同期動作例の分析

目次1. 序文2. ポップアップコンポーネントを2つ見つける3. 自分で作る3.1. Promise...

Centos7.3 で mysql5.7.18 をインストールして初期パスワードを変更する方法

この記事では、Centos7.3でのmysql5.7.18のインストールと初期パスワードの変更につい...

startup.bat をダブルクリックすると Tomcat がクラッシュする問題の解決方法の詳細な説明

Tomcat を学習したばかりのプログラマーにとって、これはよくある間違いです。 1. 環境変数の問...

ウェブページを作成する際に注意すべき点

--ホームページのバックアップ1.txtテキスト2. 画像をスキャンする3. PSDデザイン原画(A...

nginxのインストールと設定の詳細なプロセス記録

目次1 nginxの紹介1 nginxとは何か2 つのアプリケーション シナリオ2 nginxのイン...

CSSの使用に関する深い理解 clear:both

clear:both清除浮動これは私が常に持っていた印象ですが、私はこれをめったに使用せず、私の理...

MySQLトランザクションとMySQLログの詳細な説明

取引特性1. アトミック性: トランザクションの開始後、すべての操作が完了するか、まったく実行されな...

DockerコンテナはホストのMySQL操作にアクセスする

背景:インターフェイスを提供する Flask プロジェクトがあり、これは Docker コンテナを使...

nginx proxy_cache キャッシュ設定の詳細な説明

序文:私は仕事柄、オンラインライブストリーミングの分野に携わっており、ビデオの再生やダウンロードには...