ホームページ >データベース >mysql チュートリアル >一部のカテゴリに製品がない場合でも、MySQL ですべてのカテゴリとその最小/最大製品価格を取得する方法
MySQL で行が等しくない 2 つのテーブルから選択する
カテゴリと商品という 2 つのテーブルを持つオンライン ショッピング データベースでは、一般的なタスクは次のとおりです。すべてのカテゴリと各カテゴリの最小および最大の製品価格を取得します。ただし、単純なクエリでは問題が発生します。製品のないカテゴリが結果から除外されます。
この課題に対処するには、暗黙的結合の代わりに外部結合を使用する必要があります。外部結合を使用すると、もう一方のテーブル (製品) に対応する行がない場合でも、一方のテーブル (この場合はカテゴリ) から行を取得できます。具体的には、ここでは左結合が使用されているため、すべてのカテゴリが結果に含まれます。
さらに、製品のないカテゴリの null 値を 0 に置き換えるには、IFNULL() 関数が使用されます。この関数は、最初の引数で指定された式の値を受け取り、それが null の場合は、代わりに 2 番目の引数で指定された値を返します。
更新されたクエリ構文は次のとおりです。
SELECT sc.*, IFNULL(MIN(s.price), 0) AS minp, IFNULL(MAX(s.price), 0) AS maxp FROM categories AS sc LEFT JOIN products AS s ON s.ownerid = sc.id GROUP BY sc.id
外部結合と IFNULL() 関数を使用することで、すべてのカテゴリを取得し、製品のないカテゴリが minp 値と maxp 値 0 で表されるようにすることができます。このクエリは、一方のテーブルのすべての行にもう一方のテーブルに対応するエントリがない場合でも、2 つのテーブルから選択する必要があります。
以上が一部のカテゴリに製品がない場合でも、MySQL ですべてのカテゴリとその最小/最大製品価格を取得する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。