我想计算已禁用且有选项的产品。 首先我尝试检查一个表oc_product产品被禁用然后我想检查这个状态(如果禁用产品)和产品ID检查另一个表是否该产品ID有选项。
我尝试这样,但只显示状态= 0产品的结果。
select COUNT(*)
FROM oc_product
WHERE status=0
AND product_id IN ( SELECT product_id FROM oc_product_option)
答案 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