在mysql查询中使用if条件计数

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)

  • 甚至SUM(ccc_news_comments.id ='approved')作为特定于MySQL的技巧 (10认同)
  • @mojuba 不是 100% 相同,当“COUNT”(无条件)返回“0”时,您的技巧会返回“null”。当“COUNT”返回除*0之外的任何内容,但“SUM”*确实*返回0时,您的技巧将返回“0”。 (2认同)

moj*_*uba 55

更好(或更短):

SUM(ccc_news_comments.id = 'approved')
Run Code Online (Sandbox Code Playgroud)

这是有效的,因为MySQL中的布尔类型表示为INT 01,就像在C中一样.(虽然可能不能跨数据库系统移植.)

至于COALESCE()其他答案中提到的,许多语言API 在获取值时自动转换NULL''.例如,使用PHP的mysqli界面,可以安全地运行您的查询COALESCE().

  • 这使得sql代码更具可读性.美丽的方案. (3认同)

小智 19

这应该工作:

count(if(ccc_news_comments.id = 'approved', ccc_news_comments.id, NULL))
Run Code Online (Sandbox Code Playgroud)

count()仅检查值是否存在.0相当于一个存在的值,所以它再计数一次,而NULL就像一个不存在的值,因此不计算.


Mos*_*cho 5

替换这一行:

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)


小智 5

count(ccc_news_comments.id = 'approved' or null)
Run Code Online (Sandbox Code Playgroud)

更简洁