ホームページ >データベース >mysql チュートリアル >mysql インデックスは通常どのようなデータ構造を使用しますか?

mysql インデックスは通常どのようなデータ構造を使用しますか?

(*-*)浩
(*-*)浩オリジナル
2019-06-05 14:46:134904ブラウズ

MyISAM は、MySQL 5.5 より前のバージョンのデフォルトのストレージ エンジンです。5.5 以降は、InnoDB が MySQL のデフォルトのストレージ エンジンになり始めます。

MyISAM は、B ツリーを使用して主キー インデックス、一意のインデックス、および非主キー インデックスを実装します。

InnoDB の非主キー インデックスは B-Tree データ構造を使用しますが、主キー インデックスは B-Tree を使用します。

mysql インデックスは通常どのようなデータ構造を使用しますか?

B ツリー

B ツリー (バイナリではなく多方向検索ツリー) は、一般的なデータ構造です。 B ツリー構造を使用すると、レコードを検索する際の中間プロセスが大幅に削減され、アクセスが高速化されます。翻訳によれば、B は通常、Balance の略語であると考えられています。このデータ構造は通常、データベースのインデックス作成に使用され、全体的な効率が高くなります。

パフォーマンス(推奨学習: MySQL ビデオ チュートリアル)

B ツリーには次の特徴があります:

1. キーワードコレクションはツリー全体に分散されます;

2. すべてのキーワードが表示され、1 つのノードにのみ表示されます;

3. 検索は非リーフ ノードで終了する場合があります;

4. キーワードの完全なセットにおける二分検索と同等の検索パフォーマンス;

5. 自動階層制御;

B Tree

# #異なるストレージ エンジンはストレージに異なるデータ構造を使用する可能性があります。InnoDB は B ツリーを使用します;

それでは、B ツリーとは何ですか?
B ツリーは、ファイル システムに必要な B ツリーのバリアントです。m 次の B ツリーと m 次の B ツリーの違いは次のとおりです:

B と B - (つまり B) は、各ノードのキーワードが異なるためです。もう 1 つ、1 つ減ります。

B-tree の場合、ノード構造は B-tree と同じですが、各ノードのキーワードと持つことができる子ノードの数が異なります。たとえば、m 次の B ツリーでは、各ノードは最大 m 個の子ノードを持つことができます。非ルートノードには少なくとも [m/2] 個の子ノードがあり、キーワードの数は B ツリーより 1 つ多く、[m/2] ~ m です。

インデックスを処理するためのこれら 2 つのデータ構造の違い:

1.同じキー値が B ツリーに複数回出現することはなく、リーフ ノードまたは非リーフ ノードに出現する可能性があります。 B ツリーのキーは必ずリーフ ノードに表示されますが、B ツリーのバランスを維持するために非リーフ ノードにも繰り返し表示される場合があります。

2. B ツリー キーの位置は不確実であり、ツリー構造全体で 1 回しか出現しないため、記憶域を節約できますが、挿入および削除操作は大幅に複雑になります。それに比べて、B ツリーはより良い妥協案です。

3. B ツリーのクエリ効率はツリー内のキーの位置に関係します。最大時間計算量は B ツリー (葉ノードにある場合) と同じで、最小時間計算量は 1 (ルートノードにある場合)。 B ツリーの時間計算量は、構築された特定のツリーに対して固定されます。

MySQL 関連の技術記事の詳細については、MySQL データベース グラフィック チュートリアル 列にアクセスして学習してください。

以上がmysql インデックスは通常どのようなデータ構造を使用しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。