如果没有找到记录,MySQL计数不返回0

Jak*_*kob 4 php mysql record count

虽然我研究了这个主题并遇到了一些解决方案,比如使用JOIN LEFT或子查询,我仍然无法得到我想要的结果,因为我在mySQL中并不强大.我更像是一个网页设计师,试图将更简单的PHP用于我的网站,更好地用于学校项目.

我正在尝试创建类似于博客的Web应用程序.我想计算一篇帖子有多少评论并显示我的用户要查看的数字,但如果该行没有评论,我的查询将返回任何内容而不是0.

这是我的查询:

SELECT post.post_id, COUNT(comment) 
FROM `comment`, post 
WHERE `comment`.post_id = post.post_id 
GROUP BY post.post_id
Run Code Online (Sandbox Code Playgroud)

结果:

Record | post_id | COUNT(comment)
1      | 12      | 2
2      | 13      | 1
3      | 15      | 1
4      | 16      | 1
Run Code Online (Sandbox Code Playgroud)

如您所见,post_id 14没有注释,因此我的查询不返回任何内容.我该怎样做才能使我的结果看起来像这样?

Record | post_id | COUNT(comment)
1      | 12      | 2
2      | 13      | 1
3      | 14      | 0
4      | 15      | 1
5      | 16      | 1
Run Code Online (Sandbox Code Playgroud)

此外,你们很高兴给我参考或链接,以了解解决方案背后的概念,因为我想了解更多关于PHP :)

reg*_*ero 7

所以当你这样做时(这就是你所做的,为JOIN重新制定):

SELECT post.post_id, COUNT(comment) 
FROM `comment`
INNER JOIN post ON `comment`.post_id = post.post_id 
GROUP BY post.post_id;
Run Code Online (Sandbox Code Playgroud)

您只收集在评论中至少有一个引用的帖子行.

如果将JOIN类型更改为LEFT联接,则这样:

SELECT post.post_id, COUNT(comment) 
FROM `comment`
LEFT JOIN post ON `comment`.post_id = post.post_id 
GROUP BY post.post_id;
Run Code Online (Sandbox Code Playgroud)

然后post中的行都在那里,如果没有与该行相关的注释(这是左连接),则为注释列插入NULL值.因此,如果comment是表注释中的一列,它将存在于post表的每一行,但是具有NULL值,在post_id列上的group by之后,与此帖相关的注释子集仅包含1 NULL值,计数应该返回0.

select count(NULL);
Run Code Online (Sandbox Code Playgroud)

返回0.

现在你可以使用一个子查询,但这是一个非常糟糕的主意,通常是子查询而不是LEFT JOINS,通常这是一个错误,有时它不是,但它通常是一个错误.当您执行左连接时,索引用于比较2个表的键值(ON子句)并构建一个最终的'临时'行结果,混合来自两个表的值(然后,或者可能在同一时间,应用查询其他部分的过滤器).当您使用子查询时,对于第一个表的每一行,运行一个新查询以从第二个表中获取结果(并非总是如此,但这是另一个问题),数据库引擎的成本实际上要大得多.