序文カバーリング インデックスについて説明する前に、まずそのデータ構造である B+ ツリーを理解する必要があります。 まず、デモンストレーション用のテーブルを作成します (簡単にするために、ID は順番に作成されます)。
主キー以外の列値をキー値として構築されたB+ツリーインデックスを非クラスター化インデックスと呼びます。 非クラスター化インデックスとクラスター化インデックスの違いは、非クラスター化インデックスのリーフ ノードにはテーブル内のデータが格納されず、列に対応する主キーが格納されることです。データを検索する場合は、主キーに基づいてクラスター化インデックスも検索する必要があります。クラスター化インデックスに基づいてデータを検索するこのプロセスは、テーブル リターンと呼ばれます。 B+ ツリーB+ ツリーと B ツリーは、MySQL インデックスでよく使用されるデータ構造です。B+ ツリーは、B ツリーをさらに最適化したものです。上記の表を分析のためにグラフに変換してみましょう。 B+ツリーの特徴: 1. B+ツリーの非リーフノードはデータを保存せず、キー値のみを保存します。 2. リーフノードのデータは順番に並べられる 3. B+ツリーのページは双方向リンクリストで接続されています クラスター化インデックスと非クラスター化インデックスB+ ツリー インデックスは、保存方法の違いにより、クラスター化インデックスと非クラスター化インデックスに分けられます。 クラスター化インデックス: ストレージ エンジンとして InnoDB を使用するテーブルの場合、テーブル内のすべてのデータに主キーが設定されます。主キーを作成しなくても、システムによって暗黙的な主キーが作成されます。 これは、InnoDB がデータを B+ ツリーに格納し、B+ ツリーのキー値が主キーとなるためです。テーブル内のすべてのデータは、B+ ツリーのリーフ ノードに格納されます。 主キーを B+ ツリー インデックスのキー値として使用するこのような B+ ツリー インデックスは、クラスター化インデックスと呼ばれます。 非クラスター化インデックス: 主キー以外の列値をキー値として構築されたB+ツリーインデックスを非クラスター化インデックスと呼びます。 非クラスター化インデックスとクラスター化インデックスの違いは、非クラスター化インデックスのリーフ ノードにはテーブル内のデータが格納されず、列に対応する主キーが格納されることです。データを検索する場合は、主キーに基づいてクラスター化インデックスも検索する必要があります。クラスター化インデックスに基づいてデータを検索するこのプロセスは、テーブル リターンと呼ばれます。 カバーインデックスを使用してテーブルバックを回避する方法非主キー インデックスを使用しているのに、テーブルが返されるのはなぜでしょうか。簡単に言うと、非主キー インデックスは非クラスター化インデックスです。B+ ツリーのツリー子ノードには、主キーと非主キー インデックスのみが保存されます。1 つのクエリで見つけられるのは、この 2 つのフィールドだけです。3 つのフィールドを見つけたい場合は、クラスター化インデックスを再度検索する必要があります。これがテーブルが返される理由です。 たとえば、新しいフィールド age がテーブルに追加され、name を使用してインデックス (非クラスター化インデックス) が作成されます。
name = 'zs' の場合、ユーザーから id、name を選択します。 名前インデックスにヒットできます。インデックス リーフ ノードには主キー ID が格納されます。ID と名前は、テーブルに戻らずに名前インデックス ツリーを通じて取得できます。これにより、インデックス カバレッジ要件が満たされ、非常に効率的です。 name = 'zs' の場合、ユーザーから id、name、age を選択します。 名前インデックスはヒットできます。インデックス リーフ ノードには主キー ID が格納されていますが、年齢フィールドはクエリのテーブルに戻ることによってのみ取得できるため、インデックス カバレッジを満たしていません。年齢フィールドを取得するには、ID 値を通じてコードを再度スキャンする必要があり、効率が低下します。 結論: では、テーブル リターンを回避するにはどうすればよいでしょうか? 簡単です。単一列インデックス (名前) を結合インデックス (名前、年齢) にアップグレードします。 要約するこれで、MySQL でカバーリング インデックスを使用してテーブル リターンを回避し、クエリを最適化する方法についての記事は終わりです。MySQL でカバーリング インデックスを使用してテーブル リターンを回避し、クエリを最適化する方法についての関連記事については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: Vue ライフサイクルの紹介とフック関数の詳細な説明
ネットワークリクエストを送信すると、次の保存情報が表示されます。おめでとうございます。ドメインを越え...
ステップ1: 現在のカーネルを表示する 読み取る $ uname -a Linux rew 4.15...
目次負荷分散負荷分散分類1. DNS 負荷分散2. IP負荷分散3. リンク層の負荷分散4. ハイブ...
イメージを構築するこれまで、テストやデモンストレーションにさまざまなイメージを使用しました。多くの場...
まずpostcss-pxtoremをインストールします: npm install postcss-p...
ビジネス上のニーズにより、急ぎの購入が発生することが多いため、ロード バランシング フロント エンド...
私は通常、大手ウェブサイトの特別ページや製品リリースページを訪問するのが好きです。なぜなら、たくさん...
目次1. Tsとは何か2. 基本的な文法1. プリミティブデータ型を宣言する2. オブジェクト型を宣...
ReactライフサイクルReactのライフサイクルを理解するのに役立つ2つの図React ライフサイ...
GUNスクリーン:公式サイト: http://www.gnu.org/software/screen...
目次1. メニューをクリックしてジャンプ1. ページ名の統一2. 管理ページを追加3. ルートを追加...
デフォルトでは、ラベルとスパンの幅の設定は無効です。一般的に、表示属性は必須ですコードをコピーコード...
1. 公式サイト http://dev.mysql.com/downloads/mysql/ から ...
目次ウェブパック5公式スタート建築ガイド構築を開始する依存する準備が完了したら、プロジェクトの構築を...
ご存知のとおり、mailto は Web デザインと制作において非常に実用的な HTML タグです。...