use*_*513 97 mysql if-statement join count
我有两个表,一个用于新闻,另一个用于评论,我想得到其状态已被批准的评论的计数.
SELECT
ccc_news . *,
count(if(ccc_news_comments.id = 'approved', ccc_news_comments.id, 0)) AS comments
FROM
ccc_news
LEFT JOIN
ccc_news_comments
ON ccc_news_comments.news_id = ccc_news.news_id
WHERE
`ccc_news`.`category` = 'news_layer2'
AND `ccc_news`.`status` = 'Active'
GROUP BY
ccc_news.news_id
ORDER BY
ccc_news.set_order ASC
LIMIT 20
Run Code Online (Sandbox Code Playgroud)
但是这个查询的问题是,对于该列提取的最小值是1是否存在与该消息相对应的任何注释.
任何帮助都会非常值得赞赏.
小智 240
用来sum()代替count()
试试以下:
SELECT
ccc_news . * ,
SUM(if(ccc_news_comments.id = 'approved', 1, 0)) AS comments
FROM
ccc_news
LEFT JOIN
ccc_news_comments
ON
ccc_news_comments.news_id = ccc_news.news_id
WHERE
`ccc_news`.`category` = 'news_layer2'
AND `ccc_news`.`status` = 'Active'
GROUP BY
ccc_news.news_id
ORDER BY
ccc_news.set_order ASC
LIMIT 20
Run Code Online (Sandbox Code Playgroud)
moj*_*uba 55
更好(或更短):
SUM(ccc_news_comments.id = 'approved')
Run Code Online (Sandbox Code Playgroud)
这是有效的,因为MySQL中的布尔类型表示为INT 0和1,就像在C中一样.(虽然可能不能跨数据库系统移植.)
至于COALESCE()其他答案中提到的,许多语言API 在获取值时自动转换NULL为''.例如,使用PHP的mysqli界面,可以安全地运行您的查询COALESCE().
小智 19
这应该工作:
count(if(ccc_news_comments.id = 'approved', ccc_news_comments.id, NULL))
Run Code Online (Sandbox Code Playgroud)
count()仅检查值是否存在.0相当于一个存在的值,所以它再计数一次,而NULL就像一个不存在的值,因此不计算.
替换这一行:
count(if(ccc_news_comments.id = 'approved', ccc_news_comments.id, 0)) AS comments
Run Code Online (Sandbox Code Playgroud)
有了这个:
coalesce(sum(ccc_news_comments.id = 'approved'), 0) comments
Run Code Online (Sandbox Code Playgroud)