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;
本文来自博客园,作者:天行者_sky,转载请注明原文链接:https://www.cnblogs.com/Skywal/p/15727704.html