MYSQL データベースの基礎 - 結合操作の原理

MYSQL データベースの基礎 - 結合操作の原理

結合では、ネスト ループ結合アルゴリズムが使用されます。ネスト ループ結合には 3 つの種類があります。

t1 から * を選択し、t2 を t1.a = t2.a で結合します。
-- a 100 データ項目、b 1000 データ項目

単純なネストループ結合

テーブル t1 全体が走査されます。T1 は駆動テーブルとして使用されます。t1 の各データは、t2 のテーブル全体で照会されます。このプロセスは 100*1000 回比較されます。

t2 でフル テーブル クエリが実行されるたびに、フル テーブル スキャンがメモリ内で実行されるとは限らず、バッファー プールが削除され、ディスク上に配置される可能性があります。

ブロックネストループ結合(MySQL ドライバーリンクはインデックスを使用しません)

t1 テーブル全体を走査し、t1 データを join_buffer にロードし、次に t2 テーブル全体を走査して、t2 の各データを join_buffer の t1 にキャッシュされたデータと一致させます。

t1 フルテーブルスキャン = 100 回

t2 フルテーブルスキャン = 1000 回

クエリ数 = 1100

join_bufferでの比較 = 100 * 1000回

比較回数は Simple Nested-Loop Join と同じですが、比較処理は Simple Nested-Loop Join よりもはるかに高速で、パフォーマンスも向上します。

join_buffer にはサイズがあります。t1 で見つかったデータが join_buffer のサイズより大きい場合、t1 のデータの一部が最初にロードされます。t2 を比較した後、join_buffer はクリアされ、t1 の残りのデータがロードされます。ロードが不完全な場合は、操作が繰り返されます。

t1 のフル テーブル スキャンの数は join_buffer 1 の数と同じままですが、t2 のスキャンの数はセグメントの数で乗算されます。

駆動テーブルのデータ行数は N であり、アルゴリズム プロセスを完了するにはこれを K セグメントに分割する必要があり、駆動テーブルのデータ行数は M であると仮定します。

K = λ * N

駆動テーブルをスキャンする回数 = M * λ * N

λ は join_buffer のサイズに関係します。join_buffer のサイズが十分に大きい場合、大きなテーブル ドライバーと小さなテーブル ドライバーの時間は同じになります。

セグメンテーションが必要な場合、セグメンテーション回数が少ないほど、駆動テーブルがスキャンされる回数が少なくなるため、小さなテーブル ドライバーを使用する必要があります。

インデックス ネスト ループ結合 (MySQL ドライバー リンクはインデックスを使用します)

フィールド a がインデックス付けされている場合の上記の SQL を例に挙げてみましょう。

t1 テーブル全体がスキャンされ、t1 テーブルの各データが t2 テーブルにインデックスされます。ID が見つかった後、テーブルが再度クエリされます (接続フィールドが t2 テーブルの主キーである場合、テーブル取得操作は省略されます)。

t1はテーブル全体を100回スキャンします

t2 インデックスクエリ = log1000 回

t2 テーブルクエリ = log1000 回

駆動テーブルのデータ行数が N で、駆動テーブルのデータ行数が M であると仮定します。

クエリの総数 = N + N * 2logM

上記からわかるように、駆動テーブル内のデータが大きくなるほどクエリの数も増えるため、駆動テーブルとしては小さなテーブルを使用する必要があります。

この記事は「MySQL実践45講義-講義34」について言及しています。

要約する

MYSQL データベースの結合操作原理の基本に関するこの記事はこれで終わりです。MYSQL 結合原理に関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。皆様の今後の 123WORDPRESS.COM へのご支援を心より願っております。

以下もご興味があるかもしれません:
  • 7つのMySQL JOINタイプのまとめ
  • MySQL 結合バッファの原理
  • mysql-joinsの具体的な使用方法
  • MySQL 結合クエリ構文と例
  • MySQL におけるさまざまな一般的な結合テーブルクエリの例の概要
  • MySQLの7つのJOINの具体的な使い方

<<:  HTMLポップアップdivはモバイルの中央揃えを実現するのに非常に便利です

>>:  Linux ドライバ開発でよく使われる関数 copy_from_user open read write の詳細な説明

推薦する

Linux 7.6 バイナリに MySQL 8.0.27 をインストールする詳細な手順

目次1. 環境整備1.1 オペレーティング システムのバージョン1.2 ディスク容量1.3 ファイア...

SQL 最適化チュートリアル: IN クエリと RANGE クエリ

序文「High Performance MySQL」では、インデックスでは範囲フィールドの後の部分が...

マスタークラスタに再参加する k8s ノードの実装

1. ノードを削除するkubectl delete node node01を実行します。 2. この...

Vueルーティングコンポーネントでパラメータを渡す8つの方法の詳細な説明

シングルページアプリケーションを開発する場合、特定のルートを入力し、パラメータに基づいてサーバーから...

MySQL接続クエリにおけるととwhereの違いの簡単な分析

1. テーブルを作成する テーブル「学生」を作成( `id` int(11) NULLではない、 `...

MySQL全文検索の使用例

目次1. 環境整備2. データの準備3. ショーを始める4. 単語分割エンジン要約する参考文献1. ...

MySQL マスタースレーブ同期メカニズムと同期遅延問題追跡プロセス

序文DBA として、仕事中に MySQL マスターとスレーブの同期遅延の問題に遭遇することがよくあり...

ウェブページ制作をマスターするために必要な6つのスキルのまとめ

ウェブデザイナーはジェネラリストであると言わざるを得ません。グラフィックデザイナーは、さまざまな特殊...

Kubernetes YAMLファイルの使用

目次01 YAMLファイルの概要YAML---キー値型YAML---リスト型02 K8Sにおけるマス...

MySQL でのバイナリ型操作

この記事は主にMySQLデータベースのバイナリ型操作を紹介し、具体的な内容を通して紹介します。MyS...

JavaScriptプロトタイプとプロトタイプチェーンを徹底的に理解する

目次序文基礎を築くプロトタイプコンストラクタのプロパティ__プロト__プロトタイプチェーン改善する要...

HTML と埋め込み Flash の両方におけるスクロールバーの分析と処理

開発を行う際に、次のような状況に遭遇することがよくあります。 a.swf が Web ページに追加さ...

高品質なJavaScriptコードの書き方

目次1. 読みやすいコード1. 統一コード形式2. マジックナンバーを削除する3. 単一機能原則2....

MySQL のデータ型とスキーマの最適化の詳細な説明

現在、MySQL の最適化について学習しています。この記事では、データ型とスキーマの最適化について紹...

MySQL 8.0.11 のインストールと設定方法のグラフィックチュートリアル MySQL 8.0 の新しいパスワード認証方法

この記事では、参考までにMySQL8.0.11のインストールと設定方法、およびMySQL8.0の新し...