Where 句を使用した MySQL 結合
2 つのテーブルを結合する場合、WHERE 句を使用して結果をフィルタリングできます。ただし、この句の配置は結合の効率に大きな影響を与える可能性があります。
この場合の目標は、すべてのカテゴリと特定のユーザーが購読しているカテゴリを取得することです。 LEFT JOIN を使用した最初のクエリはうまく機能しますが、ユーザー ID に WHERE 句を追加すると INNER JOIN に変換されるようです。
このジレンマを解決するには、結合条件の違いを理解することが重要です。外部結合の where 句。結合条件は結合操作の前に評価され、一致する行を定義します。一方、where 句は結合の後に動作し、結果の行セットをフィルター処理します。
正しいアプローチは、以下に示すように、結合条件自体でフィルターを指定することです。
SELECT * FROM categories LEFT JOIN user_category_subscriptions ON user_category_subscriptions.category_id = categories.category_id AND user_category_subscriptions.user_id = 1;
ON 句にフィルターを配置すると、user_category_subscriptions テーブルの一致する行のみがカテゴリ テーブルに結合されます。このアプローチはより効率的で、特定のユーザーが購読しているカテゴリーを含むすべてのカテゴリーという望ましい結果が得られます。
以上がWHERE 句の配置は MySQL LEFT JOIN の効率にどのように影響しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。