[MySQL]对空表、含有null的表使用分组函数及group by存在的问题

在MySQL中,使用count等分组函数时,空表或含null的表会返回不同结果。无group by时,空表count返回0,而含null表count返回0或总行数。使用group by后,空表返回空记录,含null表将null视为单独分组。应对策略包括使用嵌套子查询或预处理数据。
摘要由CSDN通过智能技术生成

今天写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。


这种情况其实在工作中有可能会出现,所以在

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值