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列