【MySQL】count()函数中使用条件表达式

https://www.csdn.net/tags/NtTacg4sNDIzODMtYmxvZwO0O0OO0O0O.html

 

count()函数中使用条件表达式加or null来实现,作用就是当条件不满足时,函数变成了count(null)不会统计数量

mysql> select count(num > 200 or null) from a;

 

count()函数中使用if表达式来实现,当条件满足是表达式的值为非空,条件不满足时表达式值为NULL;

mysql> select count(if(num > 200, 1, null)) from a;

 

count()函数中使用case when表达式来实现,当条件满足是表达式的结果为非空,条件不满足时无结果默认为NULL;

mysql> select count(case when num > 200 then 1 end) from a;

 

 

使用count()函数实现条件统计的基础是对于值为NULL的记录不计数,常用的有以下三种方式,假设统计num大于200的记录

select count(num > 200 or null) from a;

select count(if(num > 200, 1, null)) from a

select count(case when num > 200 then 1 end) from a

 

posted @ 2022-05-31 17:02  新茶煮酒  阅读(3761)  评论(0)    收藏  举报