ホームページ > データベース > mysql チュートリアル > ON 句を使用して左結合の前にテーブルをフィルタリングする方法

ON 句を使用して左結合の前にテーブルをフィルタリングする方法

Barbara Streisand
リリース: 2025-01-14 13:27:47
オリジナル
496 人が閲覧しました

How to Filter a Table Before a Left Join Using the ON Clause?

左結合の前にテーブルをフィルタリングします

左結合を実行する前にテーブルをフィルタするには、JOIN ステートメントの ON 句でフィルタ条件を適用します。この例の目標は、Entry テーブルを Customer テーブルに結合する前に、値「D」を持つ カテゴリ 列によって Entry テーブルをフィルタリングすることです。

<code class="language-sql">SELECT c.Customer, c.State, e.Entry
FROM Customer c
LEFT JOIN Entry e ON c.Customer = e.Customer AND e.Category = 'D'</code>
ログイン後にコピー

このクエリでは、ON 句がカテゴリ列でエントリ テーブルをフィルタリングし、カテゴリ = 'D' の行のみが結合操作に含まれるようにします。これにより、Entry テーブルに関連するレコードがあるかどうかに関係なく、Customer テーブル内のすべてのレコードを取得できると同時に、指定されたカテゴリ基準を満たさない無関係なエントリを除外できます。

このクエリの結果は次のようになります:

<code>╔══════════╦═══════╦═══════╗
║ Customer ║ State ║ Entry ║
╠══════════╬═══════╬═══════╣
║ A        ║ S     ║  5575 ║
║ A        ║ S     ║  3215 ║
║ B        ║ V     ║  4445 ║
║ C        ║ L     ║  NULL ║
╚══════════╩═══════╩═══════╝</code>
ログイン後にコピー

これは、Customer テーブルのすべての行と、Category = 'D' でフィルターされた Entry テーブルの一致するエントリを含む、予想される結果と一致します。

以上がON 句を使用して左結合の前にテーブルをフィルタリングする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート