1. はじめにICP (Index Condition Pushdown) は、MySQL 5.6 で導入されたクエリ最適化戦略です。これは、元々サーバー層で実行されていたインデックス条件チェックをストレージ エンジン層にプッシュダウンすることで、テーブル戻りとストレージ エンジン アクセスの数を減らし、クエリ効率を向上させます。 2. 原則ICP の仕組みを理解するには、まず ICP なしで MySQL がどのようにクエリを実行するかを理解しましょう。
ICP を使用する場合、クエリ プロセスは次のようになります。
III. 実践まずテーブルを作成し、レコードを挿入します テーブルユーザーの作成 ( id int(11) NOT NULL AUTO_INCREMENT COMMENT "主キー", name varchar(32) COMMENT "名前", city varchar(32) COMMENT "city", age int(11) コメント "age", 主キー(ID)、 キー idx_name_city(名前、都市) )engine=InnoDB デフォルト文字セット=utf8; ユーザーに挿入(名前、都市、年齢) 値("ZhaoDa", "北京", 20),("QianEr", "上海", 21),("SunSan", "広州", 22), ("LiSi", "深圳", 24), ("ZhouWu", "寧波", 25), ("WuLiu", "杭州", 26), ("ZhengQi", "南寧", 27), ("WangBa", "銀川", 28), ("LiSi", "天津", 29), ("ZhangSan", "南京", 30), ("CuiShi", "鄭州", 65), ("LiSi", "昆明", 29), ("LiSi", "鄭州", 30); テーブルレコードを確認する mysql> ユーザーから * を選択します。 +----+----------+----------+------+ | ID | 名前 | 都市 | 年齢 | +----+----------+----------+------+ | 1 | 趙大 | 北京 | 20 | | 2 | 千二 | 上海 | 21 | | 3 | サンサン | 広州 | 22 | | 4 | LiSi | 深圳 | 24 | | 5 | 周武 | 寧波 | 25 | | 6 | 烏柳 | 杭州 | 26 | | 7 | 鄭斉 | 南寧 | 27 | | 8 | 王巴 | 銀川 | 28 | | 9 | リーシ | 天津 | 29 | | 10 | 張三 | 南京 | 30 | | 11 | 崔市 | 鄭州 | 65 | | 12 | リーシ | クンミン | 29 | | 13 | リーシ | 鄭州 | 30 | +----+----------+----------+------+ セット内の行数は 13 です (0.00 秒) このテーブルには結合インデックス (name, city) が作成されていることに注意してください。次のステートメントをクエリするとします。 name="LiSi" かつ city like "%Z%" かつ age > 25 であるユーザーから * を選択します。 3.1 インデックスプッシュダウンを使用しないインデックス プッシュダウンを使用しない場合、ジョイント インデックスの「左端一致」の原則に従って、name 列のみがインデックスを使用できます。city 列はあいまい一致であるため、インデックスを使用できません。このときの実行プロセスは次のとおりです。
絵を描いてみましょう: インデックス条件プッシュダウンは使用されません 3.2 インデックスプッシュダウンの使用インデックス プッシュダウンを使用する場合、実行プロセスは次のようになります。
絵を描いてみましょう:
また、実行プランからインデックスプッシュダウンが使用されていることもわかります(Extraにインデックス条件の使用が表示されます) mysql> explain select * from user where name="LiSi" and city like "%Z%" and age > 25; +----+-------------+--------+-----------+--------+---------------+---------------+---------+-------+---------+---------+------------------------------------+ | id | select_type | テーブル | パーティション | タイプ | 可能なキー | キー | キー長 | ref | 行 | フィルター済み | 追加 | +----+-------------+--------+-----------+--------+---------------+---------------+---------+-------+---------+---------+------------------------------------+ | 1 | SIMPLE | user | NULL | ref | idx_name_city | idx_name_city | 99 | const | 4 | 7.69 | インデックス条件の使用; where の使用 | +----+-------------+--------+-----------+--------+---------------+---------------+---------+-------+---------+---------+------------------------------------+ セットに 1 行、警告 1 件 (0.00 秒) IV. 利用条件
5. 関連するシステムパラメータインデックス条件プッシュダウンはデフォルトで有効になっており、システム パラメータ optimizer_switch を使用して有効かどうかを制御できます。 デフォルトのステータスを表示します。 mysql> @@optimizer_switch\G を選択します。 ************************** 1. 行 **************************** @@optimizer_switch: index_merge=on、index_merge_union=on、index_merge_sort_union=on、index_merge_intersection=on、engine_condition_pushdown=on、index_condition_pushdown=on、mrr=on、mrr_cost_based=on、block_nested_loop=on、batched_key_access=off、materialization=on、semijoin=on、loosescan=on、firstmatch=on、duplicateweedout=on、subquery_materialization_cost_based=on、use_index_extensions=on、condition_fanout_filter=on、derived_merge=on セット内の 1 行 (0.00 秒) 状態を切り替える: optimizer_switch="index_condition_pushdown=off" を設定します。 optimizer_switch="index_condition_pushdown=on" を設定します。 要約するMySQL Index Pushdown (ICP) についての説明はこれで終わりです。MySQL Index Pushdown (ICP) の詳細については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: フレックスレイアウトにおける画像変形の解決策の詳細な説明
1 yumでソフトウェアをインストールしたときにダウンロードしたrpmパッケージを保存しますyum ...
開発から導入まで自分で行うシングルページアプリケーションを開発する場合、ビルドを実行した後 npm ...
オンラインで検索して重複データを削除し、ID が最小のデータだけを残します。方法は次のとおりです。 ...
写真を背景にしてリンクを記載します。たとえば、ウェブサイトのロゴ画像などです。例: ポテトのロゴ画像...
今日、Baiduのページで練習していたところ、検索ボックスとボタンの余白とパディングの値が0に設定さ...
JD カルーセルは、動的な効果を追加せず、主に位置決めの知識を使用して、純粋な HTML と CS...
目次1. MySQL論理アーキテクチャの概要2. コネクタクエリキャッシュ4. パーサー5. オプテ...
コンテナを作成する [root@server1 ~]# docker run -it --name ...
多くの場合、画像をコンテナのサイズに合わせて調整する必要があります。 1. imgタグ方式幅と高さを...
目次1 違い1.1 スペース占有1.2 表現範囲1.3 タイムゾーン2 テスト3つの選択肢MySQL...
目次序文1. 背景2. シミュレーションテスト3. 結論要約する序文もし私が罠に陥っていなかったら、...
効果環境が必要ビュー要素UIドラッグアンドドロッププラグインSortable.js必要な構成プロパテ...
1. 公式ウェブサイトから 64 ビットの zip ファイルをダウンロードします。 2. インスト...
Centos7では、/etc/rc.d/rc.localファイルの権限が削減されており、実行権限があ...
ページが応答しない場合、白い画面が表示されないように、読み込みアニメーションを表示するのがユーザーフ...