優先度
まず、2 つの概念を明確にします。
左結合の場合、2 つの違いは次のとおりです。
テスト 表1: 表1
表2: 表2
テーブル1 a から a.id、a.No、b.name を選択し、テーブル2 b を (a.No = b.No かつ b.name='aaa') で左結合します。 テーブル1 a から a.id、a.No、b.name を選択し、テーブル2 b を (a.No = b.No) で結合します。ここで、b.name は 'aaa' です。 最初の結果セット: |id |いいえ |名前| |---|---|---| |1 |n1 |aaa| |2 |n2 |(ヌル)| |3 |n3 |(ヌル)| 2番目の結果セット: |id |いいえ |名前| |---|---|---| |1 |n1 |aaa| 最初の SQL ステートメントの実行プロセスは、まずテーブル b で名前が aaa である行 (on (a.No = b.No and b.name='aaa') ) を検索します。次に、テーブル a のデータを検索し (テーブル b のルールを満たしていない場合でも)、一時テーブルを生成してユーザーに返します。 2 番目の SQL ステートメントの実行プロセスは次のとおりです。最初に一時テーブルが生成され、次に where ステートメントが実行されて、b.name='aaa' が true ではない結果セットがフィルター処理され、最後に結果がユーザーに返されます。 on は最初に条件を満たさない行を除外し、次に他の操作を実行するため、on が最も高速であることは当然です。 複数のテーブルをクエリする場合、on は where よりも先に有効になります。システムはまず、テーブル間の結合条件に基づいて複数のテーブルを一時テーブルに結合し、次に where を使用してフィルタリングしてから計算します。計算後、having を使用して再度フィルタリングします。このことから、フィルタリング条件が正しい役割を果たすためには、まず条件がいつ有効になるかを理解し、次に条件をどこに配置するかを決定する必要があることがわかります。 JOIN に関係するテーブルの関連付け操作では、接続条件を満たさない行がクエリ範囲内にある必要がある場合、接続条件を WHERE の後ではなく ON の後に置く必要があります。接続条件を WHERE の後に置くと、LEFT、RIGHT などの操作はすべて無効になります。この場合、その効果は INNER 接続とまったく同じです。行の選択に影響しない条件については、ON または WHERE の後に置くだけです。 注意: すべての接続条件は ON の後に配置する必要があります。そうしないと、以前の LEFT と RIGHT の関連付けはすべて装飾として使用され、効果がありません。 要約する 上記はこの記事の全内容です。この記事の内容が皆さんの勉強や仕事に一定の参考学習価値を持つことを願っています。ご質問があれば、メッセージを残してコミュニケーションしてください。123WORDPRESS.COM を応援していただきありがとうございます。 以下もご興味があるかもしれません:
|
>>: VMware15 centos7 ブリッジモード ssh に突然アクセスできなくなる問題を解決する
nginx の HTTP モジュールを作成する場合、リクエスト開始時のアクセス許可の有無、コンテンツ...
MySQL 5.7.18 無料インストール版のインストールチュートリアルMySQL は現在、世界で最...
Kubernetes チームは最近、最新バージョンの Docker でサポートされている機能を廃止...
HTML スタイル タグスタイルタグ - ドキュメント内でスタイルを宣言するときにこのタグを使用しま...
実装要件ElementUI を模倣したフォームは、インデックス コンポーネント、Form フォーム ...
序文ブラウザをどのようにズームしても、ボックス コンテナーの高さを常に 100% に保つ必要がある場...
任意のウェブページを開きます。例: http://www.baidu.com/ ブラウザのタブのヘッ...
目次背景問題の場所さらなる分析要約する背景私のコース「Vue 3 エンタープライズレベルの音楽アプリ...
2 列レイアウトはプロジェクトでよく使用されます。この効果を実現する方法はたくさんあります。 しかし...
以前 HTML を解析したことがあるので、今日は Vue ドラッグ アンド ドロップを使用して、Ku...
TW のメインテキスト ページは、以前は小さなモニターと低解像度のユーザーを考慮して幅が 850 ピ...
前回は、Explain 実行プランの表示、インデックスの分析など、MySQL での SQL クエリの...
1. MySQLリポジトリソースをダウンロードする$ wget http://repo.mysql....
序文MySQL では、クロスデータベース クエリは主に 2 つの状況に分けられます。1 つは同じサー...
HTML+CSS 1. WEB 標準と W3C の理解と知識<br /> タグを閉じ、小...