MySQLインデックスに関する詳細を共有する

MySQLインデックスに関する詳細を共有する

数日前、同僚からMySQLのインデックスについて質問を受けました。大体わかっているのですが、まだ練習したいと思っています。is nullやis not nullなどのクエリにインデックスを使用できますか?インターネット上の記事ではインデックスは使用できないと書いてあるかもしれませんが、実際にはそうではありません。小さな実験を見てみましょう。

テーブル `null_index_t` を作成します (
 `id` int(10) 符号なし NOT NULL AUTO_INCREMENT,
 `null_key` varchar(255) デフォルト NULL,
 `null_key1` varchar(255) デフォルト NULL,
 `null_key2` varchar(255) デフォルト NULL,
 主キー (`id`)、
 キー `idx_1` (`null_key`) BTREE 使用、
 キー `idx_2` (`null_key1`) BTREE 使用、
 キー `idx_3` (`null_key2`) BTREE 使用
)ENGINE=InnoDB デフォルト文字セット=utf8mb4;

ストアドプロシージャを使用してデータを挿入する

区切り文字 $ # 区切り文字を使用してストアド プロシージャの終了をマークします。$ はストアド プロシージャの終了を示します。create procedure nullIndex1()
始める
iをintとして宣言します。	
j int を宣言します。	
i=1 に設定します。
j=1 に設定します。
i<=100の間、	
	while(j<=100) 実行する	
		(i % 3 = 0) ならば
	   null_index_t ( `null_key`, `null_key1`, `null_key2` ) VALUES (null 、 LEFT(MD5(RAND()), 8), LEFT(MD5(RAND()), 8) ) に INSERT します。
  そうでなければ (i % 3 = 1)
			 null_index_t ( `null_key`, `null_key1`, `null_key2` ) VALUES (LEFT(MD5(RAND()), 8), NULL, LEFT(MD5(RAND()), 8)); に挿入します。
	 それ以外
			 null_index_t ( `null_key`, `null_key1`, `null_key2` ) VALUES (LEFT(MD5(RAND()), 8), LEFT(MD5(RAND()), 8), NULL) に挿入します。
  終了の場合;
		j=j+1 と設定します。
	終了しながら;
	i=i+1 と設定します。
	j=1 に設定します。	
終了しながら;
終わり 
$
nullIndex1() を呼び出します。

次に、is nullクエリを見てみましょう

EXPLAIN select * from null_index_t WHERE null_key が null の場合; 

別のものを見てみましょう

EXPLAIN select * from null_index_t WHERE null_key が null ではない;

ここから何が見えるでしょうか?考えてみましょう。

上記から、is null はインデックス付けする必要があることがわかります。したがって、少なくともこれは包括的なルールではありません。ただし、is not null は機能しないようです。小さな変更を加えて、このテーブルのデータの 9100 を null にし、残りの 900 に値を持たせて、次のコマンドを実行してみましょう。

それでは実行結果を見てみましょう

EXPLAIN select * from null_index_t WHERE null_key が null の場合;

EXPLAIN select * from null_index_t WHERE null_key が null ではない; 

違うのでしょうか?ここで付け加えておきたいのは、実験に使用したMySQLは5.7であり、他のバージョンとの整合性は保証されていないということです。
実際、データの量が変化すると、MySQL がインデックスを使用するかどうかが変化することがわかります。これは、is not null が必ず使用されるという意味でも、絶対に使用されないという意味でもありません。代わりに、オプティマイザはクエリ コストに基づいて予測を行います。この予測により、主にテーブル戻り値を含むクエリ コストが可能な限り削減されますが、完全に正確であるとは限りません。

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

以下もご興味があるかもしれません:
  • MySQLインデックスを最適化する方法
  • MySql 範囲内の検索時にインデックスが有効にならない理由の分析
  • MySql インデックスを表示および最適化する方法
  • MySQL全文インデックスの原理と欠点
  • MySQL 5.6 の「暗黙的な変換」によりインデックスが失敗し、データが不正確になる
  • MySQL 8.0 のインデックス スキップ スキャン
  • MySQL のユニークインデックスと通常のインデックスのどちらを選択すればよいでしょうか?
  • Explainキーワードに基づいてMySQLインデックス機能を最適化する方法

<<:  Q&A: XML と HTML の違い

>>:  vue3 キャッシュページキープアライブと統合ルーティング処理の詳細な説明

推薦する

MySql インデックスの詳細な紹介と正しい使用方法

MySql インデックスの詳細な紹介と正しい使用方法1. はじめに:インデックスはクエリ速度に重大な...

jQueryはマウスドラッグ画像機能を実装します

この例では、jQuery を使用してマウス ドラッグ イメージ機能を実装します。まず、ラッパーを設定...

HTML+CSS を使用して、画像の右上隅に削除の十字と画像削除ボタンを追加します。

記録として、将来使用される可能性があり、困っている友人も使用できます。 BBはもうやめて、まずはレン...

mysql の find_in_set 関数の基本的な使い方

序文これは私が最近見つけた新しい機能です。プロジェクトでの私の使用シナリオは次のとおりです。アプリケ...

Linux での一般的なシェル スクリプト コマンドと関連知識

目次1. 覚えておくべき知識1. 変数タイプ2. シェル変数の説明3. シングルクォート、ダブルクォ...

Vue のローカルコンポーネントの紹介

Vueでは、ローカルコンポーネントを自分で定義(登録)することができます。コンポーネント名を定義する...

CSS 動的読み込みバー効果のサンプルコード

CSS変数の知識を使って、追加したコードとコメントを直接投稿します <!DOCTYPE htm...

一般的なフロントエンドJavaScriptメソッドのカプセル化

目次1. 値を入力し、そのデータ型を返す** 2. アレイ重複排除3. 文字列の重複排除4. ディー...

CentOS 7 で MySQL 接続数が 214 に制限される問題の解決方法

問題を見つける最近、プロジェクトで問題が発生しました。接続が多すぎるため、「接続が多すぎます」という...

JS デコレータ パターンと TypeScript デコレータ

目次デコレータパターンの紹介TypeScript のデコレータデコレータの使用デコレーターファクトリ...

JavaScript ドラッグタイム ドラッグケースの詳細な説明

目次DragEvent インターフェースデータ転送インターフェースの概要DataTransfer の...

vue3 コンポーネントでの v-model の使用と詳細な説明

目次v-model 入力で双方向バインディングデータを使用するコンポーネント内の v-model他の...

ウェブデザインと制作におけるハイパーリンクの効果の向上

ハイパーリンクを使用すると、ページからページへ、またはサイトからサイトへ瞬時に移動できます。このよう...