数日前、同僚から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 インデックスに関する詳細を共有する詳細な内容です。MySQL インデックスの詳細については、123WORDPRESS.COM の他の関連記事に注目してください。 以下もご興味があるかもしれません:
|
>>: vue3 キャッシュページキープアライブと統合ルーティング処理の詳細な説明
DataGrid コントロールの DataSource プロパティがデザイン時に設定されている場合、...
先週末、兄弟プロジェクトはより良いサービスを提供するためにサーバーを拡張する準備をしていました。兄弟...
複数の注文を含むリストが必要です。各注文は一意にすることも、複数の注文を結合することもできます。各注...
この記事では、参考までに天気予報を実装するためのVueの具体的なコードを紹介します。具体的な内容は次...
MySQL 5.7 バージョン:方法1: SET PASSWORDコマンドを使用するフォーマット: ...
目次1. プロジェクトの説明2. Nginxイメージの作成3. MySQLイメージの作成4. PHP...
事故の背景: 数日前、プロジェクトの必要性により、サーバーに python-mysql モジュールを...
序文:以前の記事では、特定のパラメータの機能についてよく紹介してきました。しかし、MySQL パラメ...
目次序文グローバルロックテーブルロックテーブルロックメタデータ ロック (MDL ロック)要約する参...
Docker は 2013 年のリリース以来、広く注目され、ソフトウェア業界を変える可能性を秘めてい...
まず、Alibaba Cloud の公式チュートリアルをご覧ください。ファイルの説明: 1. 証明書...
序文Linux のスケジュールされたタスクを実装する方法としては、cron、anacron、at な...
環境名前財産CPU 5650 円メモリ4Gディスク20G+4TB この時点で、サーバーにはすでに次の...
Baidu には slot-scope に関する記事が既にたくさんありますが、以前よく学習しておら...
js 実行字句解析フェーズ: 形式パラメータ解析、変数宣言解析、関数宣言解析の 3 つの部分が含まれ...