今天写sql的时候发现了一些小细节。
用count(1)统计符合特定条件的用户数量时,利用月份进行分组。当没有符合条件的用户时,count(1)会返回0。
但是下面的结果却不为0:
select count(1) num
from users
where Address='Shanghai'
and Id>10010
group by Month;
很有趣的是,结果是空记录。
在多次尝试后,我发现把group by去掉之后,count(1)才会返回0:
select count(1) num
from users
where Address='Shanghai'
and Id>10010;
这种现象,我认为是因为count在group by之后执行,但是由于筛选后的临时表纪录为空,group by产生的临时表不存在,所以统计出的结果是null而不是0。
值得一提的是,这种情况下使用IFNULL函数也没有效果,因为空记录并不等同于NULL。
这种情况其实在工作中有可能会出现,所以在