mysql一个依赖于其他的

时间:2016-05-18 10:26:01

标签: php mysql

我想计算已禁用且有选项的产品。 首先我尝试检查一个表oc_product产品被禁用然后我想检查这个状态(如果禁用产品)和产品ID检查另一个表是否该产品ID有选项。

我尝试这样,但只显示状态= 0产品的结果。

select COUNT(*) 
FROM oc_product 
WHERE status=0 
  AND product_id IN ( SELECT product_id FROM oc_product_option)

2 个答案:

答案 0 :(得分:0)

如果我不解决你的问题,你想加入这些表格。

SELECT COUNT(*) FROM oc_product ocp
INNER JOIN oc_product_option ocpo ON ocpo.product_id = ocp.id
WHERE ocp.status=0 

所以只有那些行会返回选项表(product_id

中的ocpo.product_id = ocp.id

答案 1 :(得分:0)

如果我理解正确,您需要计算状态为0的所有产品,以及所有状态为0且具有选项的产品的数量。

如果是这样,LEFT OUTER JOIN产品有选项。然后,您可以从products表中计算DISTINCT product_id以获取产品计数,您可以从产品选项表中计算DISTINCT product_id以获取带有选项的产品计数。 COUNT(column_name)不计算column_name值为NULL的行,因此不会计算找不到匹配选项的产品。

SELECT COUNT(DISTINCT oc_product.product_id) AS product_count,
        COUNT(DISTINCT oc_product_option.product_id) AS product_with_options_count
FROM oc_product 
LEFT OUTER JOIN oc_product_option
ON oc_product.product_id = oc_product_option.product_id
WHERE oc_product.status = 0