左結合の前にテーブルをフィルタリングします
左結合を実行する前にテーブルをフィルタするには、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 サイトの他の関連記事を参照してください。