所以我在我的应用程序中发现了一个错误,它没有向我显示它应该有的结果。我将其追溯到以下 SQL 查询(我删除了不相关的部分)。
如您所见,查询从 wc_hncat_products
中选择行,其中相应 ID 在 wc_hncat_product_category_has_product
表中的计数 >= 1
如果我以子查询结果作为列执行查询,您可以看到结果是1
。但是当我在 WHERE 子句中使用它时,>= 1
比较失败。
SELECT `wc_hncat_products`.`id`,
(SELECT Count(*)
FROM `wc_hncat_product_categories`
INNER JOIN `wc_hncat_product_category_has_product`
ON `wc_hncat_product_categories`.`id` =
`wc_hncat_product_category_has_product`.`category_id`
WHERE `wc_hncat_product_category_has_product`.`product_id` =
`wc_hncat_products`.`id`
AND `category_id` IN ( '1' )) count
FROM `wc_hncat_products`
WHERE `id` IN ( '785' )
此查询返回一行,count
列的值为 1
SELECT `wc_hncat_products`.`id`
FROM `wc_hncat_products`
WHERE (SELECT Count(*)
FROM `wc_hncat_product_categories`
INNER JOIN `wc_hncat_product_category_has_product`
ON `wc_hncat_product_categories`.`id` =
`wc_hncat_product_category_has_product`.`category_id`
WHERE `wc_hncat_product_category_has_product`.`product_id` =
`wc_hncat_products`.`id`
AND `category_id` IN ( '1' )) >= 1
AND `id` IN ( '785' )
此查询选择 0 行..
这怎么可能?您可以看到计数实际上是 1,但是比较仍然失败,因为没有返回任何结果,而两种情况下的子查询都是相同的。
最佳答案
实现这种检查的标准方法是使用 EXISTS
.
像这样的东西应该适合你:
SELECT `wc_hncat_products`.`id`
FROM `wc_hncat_products`
WHERE EXISTS (SELECT NULL
FROM `wc_hncat_product_categories`
INNER JOIN `wc_hncat_product_category_has_product`
ON `wc_hncat_product_categories`.`id` =
`wc_hncat_product_category_has_product`.`category_id`
WHERE `wc_hncat_product_category_has_product`.`product_id` =
`wc_hncat_products`.`id`
AND `category_id` IN ( '1' ))
AND `id` IN ( '785' )
关于mysql - 错误的MySQL子查询计数比较结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42092611/