まず、MySQL のバージョンについて説明します。 mysql> バージョンを選択します(); +-----------+ | バージョン() | +-----------+ | 5.7.17 | +-----------+ セット内の 1 行 (0.00 秒) テーブル構造: mysql> desc テスト; +--------+----------------------+------+-----+---------+----------------+ | フィールド | タイプ | Null | キー | デフォルト | 追加 | +--------+----------------------+------+-----+---------+----------------+ | id | bigint(20) unsigned | NO | PRI | NULL | auto_increment | | val | int(10) 符号なし | NO | MUL | 0 | | | ソース | int(10) 符号なし | NO | | 0 | | +--------+----------------------+------+-----+---------+----------------+ セット内の 3 行 (0.00 秒) id は自動インクリメントの主キーであり、val は一意でないインデックスです。 合計500万件の大量のデータを投入します。 mysql> テストから count(*) を選択します。 +----------+ | カウント(*) | +----------+ |5242882| +----------+ セット1列(4.25秒)
mysql> select * from test where val=4 limit 300000,5; +---------+-----+--------+ | id | 値 | ソース | +---------+-----+--------+ | 3327622 | 4 | 4 | | 3327632 | 4 | 4 | | 3327642 | 4 | 4 | | 3327652 | 4 | 4 | | 3327662 | 4 | 4 | +---------+-----+--------+ 5 列セット (15.98 秒) 同じ目的を達成するために、通常は次のように書き直します。 mysql> select * from test a 内部結合 (select id from test where val=4 limit 300000,5) b on a.id=b.id; +---------+-----+--------+---------+ | id | val | ソース | id | +---------+-----+--------+---------+ | 3327622 | 4 | 4 | 3327622 | | 3327632 | 4 | 4 | 3327632 | | 3327642 | 4 | 4 | 3327642 | | 3327652 | 4 | 4 | 3327652 | | 3327662 | 4 | 4 | 3327662 | +---------+-----+--------+---------+ セット5行(0.38秒) 時間の違いは明らかです。 なぜ上記のような結果が表示されるのでしょうか? インデックス リーフ ノード データが照会されます。 次の図のようになります。 上記のように、インデックス ノードを 誰かが必ずこう尋ねるでしょう: インデックスは最初に使用されるので、最初にインデックス リーフ ノードに沿って必要な最後の 5 つのノードまでクエリを実行し、次にクラスター化インデックス内の実際のデータをクエリするのはなぜですか。これには、次の図のプロセスと同様に、5 つのランダム I/O のみが必要です。 確認済み: 上記の推論を確認するために実際にいくつかの操作を実行してみましょう。 私はこれを間接的にしか確認できません: val=4 の制限 300000,5 のテストから * を選択 mysql> select index_name,count(*) from information_schema.INNODB_BUFFER_PAGE where INDEX_NAME in('val','primary') and TABLE_NAME like '%test%' group by index_name; 空セット (0.04 秒) 現在、 mysql> select * from test where val=4 limit 300000,5; +---------+-----+--------+ | id | 値 | ソース | +---------+-----+--------+ | 3327622 | 4 | 4 | | 3327632 | 4 | 4 | | 3327642 | 4 | 4 | | 3327652 | 4 | 4 | | 3327662 | 4 | 4 | +---------+-----+--------+ セット5列(26.19秒) mysql> select index_name,count(*) from information_schema.INNODB_BUFFER_PAGE where INDEX_NAME in('val','primary') and TABLE_NAME like '%test%' group by index_name; +------------+-----------+ | インデックス名 | カウント(*) | +------------+-----------+ | プライマリ | 4098 | | 値 | 208 | +------------+-----------+ セットに2行(0.04秒) この時点で、 mysqladmin シャットダウン /usr/local/bin/mysqld_safe & mysql> select index_name,count(*) from information_schema.INNODB_BUFFER_PAGE where INDEX_NAME in('val','primary') and TABLE_NAME like '%test%' group by index_name; 空セット (0.03 秒) SQL を実行します: mysql> select * from test a 内部結合 (select id from test where val=4 limit 300000,5) b on a.id=b.id; +---------+-----+--------+---------+ | id | val | ソース | id | +---------+-----+--------+---------+ | 3327622 | 4 | 4 | 3327622 | | 3327632 | 4 | 4 | 3327632 | | 3327642 | 4 | 4 | 3327642 | | 3327652 | 4 | 4 | 3327652 | | 3327662 | 4 | 4 | 3327662 | +---------+-----+--------+---------+ セットに5行(0.09秒) mysql> select index_name,count(*) from information_schema.INNODB_BUFFER_PAGE where INDEX_NAME in('val','primary') and TABLE_NAME like '%test%' group by index_name; +------------+-----------+ | インデックス名 | カウント(*) | +------------+-----------+ | プライマリ | 5 | | 値 | 390 | +------------+-----------+ セットに2行(0.03秒) 2 つの違いは明らかです。最初の SQL は 4098 のデータ ページを そして、これは問題を引き起こします。あまりホットではないデータ ページを大量に 発生した問題: 再起動のたびに これで、MySQL で limit を使用するとパフォーマンスに影響する理由に関するこの記事は終了です。MySQL で limit を使用するとパフォーマンスにどのような影響があるかの詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: Zabbix カスタム監視 nginx ステータス実装プロセス
<tfoot> タグは、テーブル フッターのスタイルを定義するために使用されます。基本構...
最初のもの: 1. 主要なヘッダーファイルを追加します。 #include <linux/of...
画像をダウンロードMySQLイメージの選択 docker 検索 mysql MySQL 5.7 イメ...
目次序文1. リクエストをキャンセルする方法2. 重複リクエストの判定方法3. 繰り返しリクエストを...
現象Dockerコンテナを起動する docker run –name [コンテナ名] [コンテナID...
1.ロックしますか? 1.1 ロックとは何ですか?ロックの本当の意味は、鍵またはコードで開くことがで...
要素UIとはelement-ui は、Ele.me のフロントエンド チームが開発者、デザイナー、製...
背景私は新しいプロジェクト チームに配属されたので、プロジェクトでは js を使用する必要があります...
インターネット上には、expect を使用して自動ログインを実現するスクリプトが多数存在しますが、明...
<br />記事と同様に、Web ページにも明確な段落と重要度の異なるタイトルが必要です...
目次1. MySQLをダウンロードする2. MySQLをインストールする3. MySQL の基本的な...
前の章では、高性能な MySQL に不可欠な、最適化されたデータ型の選択方法とインデックスの効率的な...
一般的に言えば、より完全な結果を得るためには、2 つ以上のテーブルから結果を取得する必要があります。...
目次概要setTimeout() の確認スリープ関数の書き方シンプルな選択ループで実行されますか?要...
glibc は、gnu によってリリースされた libc ライブラリ、つまり c ランタイム ライブ...