MySQLインデックスの詳細

MySQLインデックスの詳細

1. インデックスの原則

インデックスは、列内の特定の値を持つ行をすばやく見つけるために使用されます。インデックスがない場合、MySQL は最初のレコードから開始し、関連する行が見つかるまでテーブル全体を読み取る必要があります。テーブルが大きいほど時間がかかります。順序付けられたフィールドにはバイナリ検索を適用できるため、パフォーマンスが大幅に向上します。 MYISAMとINNODBはどちらもインデックス構造としてB+Treeを使用しています。

(主キーと一意キーはデフォルトでインデックスを追加します)

2. インデックスを作成する

インデックスを使用しない場合、1500 を超える給与を照会するときにテーブル全体のスキャンが実行されます。

フィールドにインデックスを追加する必要があるのはいつですか?

- テーブル内のこのフィールドのデータ量は膨大です

- 頻繁に検索され、where句に頻繁に出現するフィールド

- DMLで頻繁に操作されるフィールドにインデックスを追加することは推奨されません。

索引は本の目次のようなものです。

主キーは自動的にインデックスを追加するため、主キーに基づいてクエリを実行する方が効率的です。

sal に基づいて頻繁にクエリを実行し、パフォーマンスのボトルネックが発生する場合は、まずプログラムにアルゴリズムの問​​題があるかどうかを確認し、次に sal のインデックス作成を検討してください。インデックスは次のように作成されます。

1. テーブル名(列名)に一意のインデックス インデックス名を作成します。

emp(ename) に一意のインデックス u_ename を作成します。

2. テーブルテーブル名を変更し、一意のインデックスインデックス名(列名)を追加します。

2. テーブルテーブル名を変更し、一意のインデックスインデックス名(列名)を追加します。 

3. インデックスを表示する

emp からインデックスを表示します。 

4. インデックスを使用する

select * を使用してはいけないことに注意してください... type!=all が表示され、インデックスが使用されていることがわかります

sal > 1500 の場合、emp から sal を選択します。

条件内のsalはインデックスを使用する

上記のように、sal が 1500 より大きいすべての行を検索する場合は、インデックスをスキャンできます。インデックスはソートされ、結果は 7 行になります。一致するレコードはもう存在しないことがわかっているので、終了できます。

インデックス テーブル内の中間ポイントより前に表示されない値を探している場合は、テーブルを順次スキャンせずに最初に一致するインデックス エントリを見つける位置アルゴリズム (バイナリ検索など) もあります。

この方法では、最初に一致する値をすばやく見つけることができるため、検索時間を大幅に節約できます。データベースはさまざまな手法を使用してインデックス値をすばやく見つけますが、これは通常 DBA の作業です。

5. インデックスを削除する

DROP INDEX index_name ON talbe_name

ALTER TABLE テーブル名 DROP INDEX インデックス名

ALTER TABLE テーブル名 DROP PRIMARY KEY

最初の 2 つのステートメントは同等であり、table_name 内のインデックス index_name を削除します。

テーブルには PRIMARY KEY インデックスを 1 つしか持つことができないため、3 番目のステートメントは PRIMARY KEY インデックスを削除する場合にのみ使用されます。

mysql> ALTER TABLE EMP DROP INDEX test_index;

削除後、インデックスは使用されなくなり、クエリは完全なテーブルスキャンを実行します。

上記はMySQLインデックスの詳細な理解に関する内容です。MySQLインデックスの詳細については、123WORDPRESS.COMの他の関連記事に注目してください。

以下もご興味があるかもしれません:
  • MySQL インデックス作成方法、構文構造、および例
  • MySQLの複合インデックス方式の詳細な説明
  • MySQL インデックスの知識の要約
  • MySql ストレージ エンジンとインデックスに関する知識のまとめ
  • MySQL のインデックスの種類と基本的な使用例
  • MySQL 8の新機能である降順インデックスの基礎となる実装の詳細な説明
  • インデックスとテーブルリターンをカバーするMySQLの使い方
  • MySQL のインデックス障害の一般的なシナリオと回避方法
  • Mysql データベースの高度なビュー、トランザクション、インデックス、自己接続、ユーザー管理の例の分析の使用
  • MySQLインデックスの基本構文

<<:  JavaScriptイベント実行メカニズムの深い理解

>>:  Win10+Ubuntu 20.04 LTS デュアル システム インストール (UEFI + GPT) (画像とテキスト、複数の画像には注意)

推薦する

Reactでプロキシを有効にする2つの実用的な方法

プロキシを有効にする2つの方法React には、直接使用できるカプセル化された Ajax リクエスト...

Axiosは繰り返しのリクエストをキャンセル

目次序文1. リクエストをキャンセルする方法2. 重複リクエストの判定方法3. 繰り返しリクエストを...

Vue ElementUI で Excel ファイルを手動でサーバーにアップロードする方法の詳細な説明

目次概要プロパティ設定処理ロジック概要具体的な需要シナリオは次のとおりです。 Excel ファイルを...

MySQL 使用仕様の概要

1. InnoDBストレージエンジンを使用する必要がありますCPU と IO のパフォーマンスが向上...

uniapp 要素ノードスタイルの動的変更の詳細な説明

目次1. スタイル属性をバインドして変更するhtml:対応するjs:達成された効果:次に、refを使...

ウェブアニメーションのフレームレートFPSを計算する方法

目次スムーズなアニメーションの基準方法1: Chromeデベロッパーツールを使用する方法 2: フレ...

nuxt.js 複数の環境変数の設定

目次1. はじめに2. シナリオ3. 環境を整える3.1 環境変数の挿入4. 最後に1. はじめに一...

MySQL データベースの基本的な SQL ステートメントの概要

この記事では、例を使用して、Mysql データベースの基本的な SQL ステートメントについて説明し...

MySQLデータを復元する2つの方法

1. はじめに少し前、開発者がテスト環境や本番環境で誤った操作をし、データベースを誤って削除/更新し...

Vue3スタイルのCSS変数注入の実装

目次まとめ基本的な例モチベーションデザインの詳細コンパイルの詳細採用戦略練習するヒント適切なプロパテ...

JavaScriptでポインターの位置を取得する方法を教えます

JavaScript でポインターの位置を取得する方法は、イベント オブジェクトの pageX と ...

Docker デプロイメント RabbitMQ コンテナ実装プロセス分析

1. イメージをプルするまず、次のコマンドを実行して、イメージをローカル コンピューターにダウンロー...

MySQLは遅いSQLを開始し、原因を分析します

ステップ1. MySQLスロークエリを有効にする方法1: 設定ファイルを変更するWindows: W...

CSS floatプロパティの詳細な説明

1. フローティングとは何ですか?フローティングは、その名の通り、浮遊することを意味します。要素がド...

Vue Elementのテーブルコンポーネントをカプセル化する方法

Vue コンポーネントをカプセル化する場合でも、機能コンポーネントをクロスファンクショナルに使用しま...