Null和空值对于avg计算时产生的影响以及处理

  为什么要关注这一块呢:1.面试中可能会有涉及 2.工作中真的也可能会用,既然有可能我也用过,就拿出来跟大家分享一下,上一篇的博文,数据已准备好就不做数据准备的介绍了。

  step1:select * from a; ---进行数据查询

 

 

  step2: select avg(number) from a;   ---求平均值

 

 

 分析:从上述结果来看,他是除了4,我们可以在单独验证是空字符串没有算行还是null值没有算呢,通过我们的实验发现是null没有算行。

在实际情况中我们要根据实际需要判断空字符串行以及null值所在的行要不要加入到计算行业中,这个时候我们就要引入我们的count函数根据实际需要灵活计算;

一、第一种空字符串和null值所在的行要加入到计算范围中:

select sum(number)/count(*)  as avg from a;

 

二、第二种空字符串和null值所在的行不要加到计算范围中:

`IF`(expr1,expr2,expr3)   ----使用if函数,若满足条件1,则返回expr2,不满足条件则返回expr3

问题关键就在于我们的count要把null和空字符全部剔除,首先使用我们的if函数把所有空字符串转化成null,然后使用count(字段)---会自动过滤掉我们的null值所在的行

count(if(number ='',null,number))

select sum(number)/count(if(number ='',null,number)) as avg from a;

 

 

posted @ 2021-12-24 15:48  天行者_sky  阅读(185)  评论(0编辑  收藏  举报