mysql 分组后的count 注意点

1:分组后的count 是求每一组中的行数

如果是没有分组的count 是求所有的行数

如果要在 count里加条件 注意:要加上 OR NULL

直接count(age='1')有什么问题吗?不就是要找age= '1'的数据吗,为什么要计算NULL的数据

原因: 如果当 条件不满足时 count里面 是false 是false 他也会统计上 只有除了null值的不会被统计其他都会被统计 所以我们加上逻辑判断 or null 如果不满足就为null 为null就不会统计到count里面

总结 :

1:分组后的count 是对每一组的行数进行统计

2:count 里面的条件要加上 or null

扩展:

group by 是对组进行过滤 而where是对行  聚合函授执行完后 会执行 Having 对每一组进行过滤 可以使用聚合函数 对每一组里面的数据操作


版权声明:本文为weixin_56314079原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。