Mysql sum(if())和count(if())的用法

Posted 可小辉

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mysql sum(if())和count(if())的用法相关的知识,希望对你有一定的参考价值。

SELECT SUM(if(category=1,size,0)) ,COUNT(if(category=1,true,null)) FORM t_file;

解析:
1. sum(if(category=1,size,0))中 sum函数返回一个值类型的数值,如果category=1,则返回size,如果category不等于1就返回0。


2. count(if(category=1,true,null))中count函数返回一个布尔值类型的数值,如果category=1,返回true,如果category不等于1返回null,如果写成count(If(category=1,1,0) 则返回的全是true,也就是说全都会计数,而count()间断内容是true还是null,如果不是null就计数,如果是null就不计数。
 

所以count(if())的写法应该是count(if(表达式表达式,true,null));

以上是关于Mysql sum(if())和count(if())的用法的主要内容,如果未能解决你的问题,请参考以下文章

MongoDB相当于MySQL:select count(*) c, sum(if(x='A',1,0)) as a, sum(if(x='B',1,0)) as b

Mysql中sum()与if()联合使用

Mysql中sum()与if()联合使用

mysql 带条件的sum/count 使用技巧

mysql 带条件的sum/count 使用技巧

mysql查询