null在mysql中的不同表现

  在mysql中count(*)和count(id)具有不同的表现,其最大的影响是在我们进行联表的时候,如,我们现在要查询一个文章的评论数量,使用左连接查询,具体的sql语句如下:

SELECT a.*,count(b.*) num FROM `article` a LEFT JOIN comments b ON a.id = b.article_id GROUP BY a.id;

SELECT a.*,count(b.id) num FROM `article` a LEFT JOIN comments b ON a.id = b.article_id GROUP BY a.id;

  我们知道,左连接是左表为主,右表没有查询到记录时会以null补充,那么此时我们使用count(b.*)这样统计的结果会把null列计算上,而count(b.id)不会统计null列

posted @ 2018-10-23 13:20  Mr-Qiang  阅读(97)  评论(0编辑  收藏  举报