MySQLインデックスに関する重要な面接の質問をいくつか共有します

MySQLインデックスに関する重要な面接の質問をいくつか共有します

序文

インデックスは、データベース内の 1 つ以上の列の値を並べ替え、データベースが効率的にデータを取得するのに役立つデータ構造です。

たとえて言うと、データベースのインデックスは本の目次に相当します。本の中の知識ポイントを見つけたいとき、本のすべてのページを検索する代わりに、目次で直接探すことができます。しかし、これはインデックスの欠点でもあります。データベースを変更するとき、インデックスの変更にはより多くの時間がかかります。

しかし、MySQL インデックスを本当に理解していますか?これらの質問は、インデックスに関するいくつかの重要な知識ポイントを理解するのに役立ちます。

1. 最左接頭辞原理とは何ですか?

以下の回答はすべてMySQLのInnoDBエンジンに基づいています

例えば次の表の場合

B+ツリー構造を使用して名前フィールドに基づいてインデックスを作成すると、おおよそのインデックス構造は次のようになります。

名前が「张」で始まるすべての人のIDを見つけるためにあいまい検索を実行したい場合、SQL文は次のようになります。

名前が「张%」のようなテーブルから ID を選択

B+ ツリー構造インデックスでは、インデックス項目はインデックス定義に表示されるフィールドの順序に従ってソートされます。検索時に、インデックスは ID が 100 の Zhang Yi をすばやく見つけ、条件が満たされなくなるまで、名前が Zhang で始まるすべての人物を右に直接移動します。

つまり、条件を満たす最初の人を見つけたら、そのまま右にトラバースすることができます。インデックスは順序付けされているため、条件を満たすすべての人が集められます。

左に配置してから右に移動するこの方法は、最左接頭辞原則と呼ばれます。

2. インデックスとしてハッシュ テーブルではなく B+ ツリーを使用するのはなぜですか?

1. ハッシュ テーブルは、インデックス フィールドを対応するハッシュ コードにマッピングし、対応する位置に格納します。このように、あいまい検索を実行する場合、ハッシュ テーブル構造は明らかにサポートされておらず、テーブルをトラバースすることしかできません。 B+ ツリーは、最左プレフィックス原理を通じて対応するデータをすばやく見つけることができます。

2. 100 から 400 までの ID を持つ人を検索するなど、範囲検索を実行する場合、ハッシュ テーブルはこれをサポートしていないため、テーブル全体を走査することしかできません。

3. インデックス フィールドはハッシュ化によってハッシュ コードにマップされます。多数のフィールドが同じ値のハッシュ コードにマップされると、結果として得られるインデックス構造は非常に長いリンク リストになり、検索時間が大幅に増加します。

3. 主キー インデックスと非主キー インデックスの違いは何ですか?

たとえば、次のテーブルの場合 (実際には、上記のテーブルに k フィールドが追加されています)、ID が主キーになります。

主キーインデックスと非主キーインデックスの概略図は次のとおりです。

ここで、R は行全体の値を表します。

図から、主キー インデックスと非主キー インデックスの違いは、非主キー インデックスのリーフ ノードには主キー値が格納され、主キー インデックスのリーフ ノードにはデータの行全体が格納されることであることが簡単にわかります。非主キー インデックスはセカンダリ インデックスとも呼ばれ、主キー インデックスはクラスター化インデックスとも呼ばれます。

これら 2 つの構造に基づいてクエリを実行し、クエリの違いを確認してみましょう。

1. クエリ ステートメントがselect * from table where ID = 100場合、つまり主キー クエリ メソッドの場合、ID の B+ ツリーのみを検索する必要があります。

2. クエリ ステートメントがselect * from table where k = 1場合、つまり非主キー クエリの場合は、最初に k インデックス ツリーを検索して ID = 100 を取得し、次に ID インデックス ツリーを再度検索します。このプロセスはテーブル リターンとも呼ばれます。

さて、それらの違いがわかりますか?

4. 自動増分主キー インデックスの使用が推奨されるのはなぜですか?

この主キーインデックスツリーでは

ID = 650 のデータ行を挿入する場合は、右端に挿入するだけです。

ただし、ID = 350 のデータ行を挿入する場合、B+ ツリーは順序付けされているため、ID = 350 のデータを挿入するためのスペースを確保するために、下のリーフ ノードを移動する必要があり、時間がかかります。R4 が配置されているデータ ページがいっぱいの場合は、ページ分割操作が必要になり、さらに状況が悪化します。

ただし、主キーが自動増分である場合、挿入される各 ID は前の ID よりも大きくなるため、位置を移動したり分割したりせずに、毎回最後に挿入するだけで済み、パフォーマンスが向上します。そのため、自動インクリメント主キーを持つインデックスを使用することをお勧めします。

要約する

以上がこの記事の全内容です。この記事の内容が皆様の勉強や仕事に何らかの参考学習価値をもたらすことを願います。123WORDPRESS.COM をご愛顧いただき、誠にありがとうございます。

以下もご興味があるかもしれません:
  • MySQL FAQ コレクション
  • 2019 年最新の MySQL 面接でよく聞かれる質問 21 選の紹介
  • 上級 MySQL データベース面接の質問と回答
  • MySQL 面接でよく聞かれる質問への回答
  • 面接でよく聞かれるMySQLの質問と回答を集めて、しっかりした基礎を築く

<<:  Vue3 での watchEffect の使用に関する簡単な分析

>>:  Ubuntu 16.04.5LTS に SVN をインストールする手順

推薦する

MySQL で複数のフィールドを連結する詳細な例

MySQL クエリ結果の行フィールドの結合は、次の 2 つの関数を使用して実装できます。 1. co...

MySQLデータベースでゼロ値を含む日付の問題について簡単に説明します

デフォルトでは、MySQL は日付に 0 値を挿入することを受け入れますが、実際には日付の 0 値に...

Dockerのyumソースの設定とCentOS7へのインストールの詳細な説明

ここではCentOS7が使用されており、カーネルバージョンは [root@localhost ~]#...

HTMLフロートの使用法の簡単な分析

float の使用例左サスペンション: float:left;右サスペンション: float:rig...

Linux での MySQL データベースのマスター スレーブ同期レプリケーション構成

Linux での MySQL データベースのマスター/スレーブ同期構成の利点は、この方法をバックアッ...

MySQL マスタースレーブレプリケーション構成プロセス

メインライブラリの構成1. MySQLを設定する vim /etc/my.cn # ファイルに次の内...

トップに戻るボタンを実装するJavaScript

この記事では、トップに戻るボタンを実装するためのJavaScriptの具体的なコードを参考までに紹介...

この記事では、VUE の複数の DIV とボタン バインディングの Enter イベントを実装する方法を説明します。

現在、OK ボタンをクリックしたときやキーボードの Enter キーを押したときに操作を実行するとい...

Vueプロジェクトのパッケージングと展開の実際のプロセスの記録

目次序文1. 準備 - サーバーとnginxの使用1. サーバーを準備する2. nginxをインスト...

CSS を使用して波状のウォーターボール効果を実装するためのサンプルコード

今日は新しいCSS特殊効果、波型ウォーターボール効果を学びました。これもとても美しいです HTML:...

Linuxの運用・保守の基礎知識から上級者向け知識までをまとめました

運用保守エンジニアは、初期段階では非常に大変な仕事です。この期間中、コンピューターの修理、ネットワー...

MySQL インデックスの長所と短所、およびインデックス作成のガイドライン

1. インデックスを作成する理由(メリット)インデックスを作成するとシステムのパフォーマンスが大幅に...

Windows で IP アドレスを指定してサーバーへのリモート アクセスを設定する方法

当社には、外部ネットワークからの干渉を受けることが多いサーバーが多数あります。侵入者はポート 338...

iframe の src を about:blank に設定した後の詳細

iframe の src を 'about:blank' に設定した後、"...

vue ディレクティブ v-bind の使用と注意点

目次1. v-bind: 要素の属性にデータをバインドできる2. v-bind: は次のように省略で...