優先度
まず、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 に突然アクセスできなくなる問題を解決する
最近はビッグデータで遊んでいます。友人が私のところに来て、オンラインの Tomcat が不可解に終了...
1.MySQLレプリケーションの概念これは、プライマリ データベースの DDL および DML 操作...
docker を使用すると、ファイルをマウントできない場合があります。これは、仮想マシンの共有フォル...
目次導入ルート内のオブジェクト属性パス: 文字列コンポーネント: コンポーネント | () =>...
最近、テスト サーバーのオペレーティング システムを Cent0S 7.5 にアップグレードし、Py...
目次MySQLがmy.cnfを読み込む順序1. mysql.server の起動方法2. mysql...
この記事では、Webオンラインチャットを実装するためのVueの具体的なコードを参考までに紹介します。...
1. コマンドラインでMySQLサービスを停止します: net stop mysql stop my...
今日は、シンプルなハートビート効果を作成します。多くのコードは必要ありません。ボックスを追加し、CS...
この記事では、MySQL 5.7.18インストーラーの詳細なインストールチュートリアルを参考までに記...
目次事件の原因解剖学ファイルの並べ替えファイルのソートが非常に遅いのですが、他に解決策はありますか?...
導入: AD は Active Directory の略称で、中国語では Active Direct...
目次1. フィルター() 2. 各() 3. いくつか() 4. すべて() 5. 減らす() 6....
目次コードの実行に長い時間がかかる場合はどうなりますか? Axiosにはタイムアウト処理機能が搭載さ...
MySQL データベース管理ソフトウェアには、エンタープライズ エディションとコミュニティ エディシ...