Mysql中使用聚合函数对null值的处理

      平时因为对于数据库研习的不深,所以在面试的时候问了一些平常遇到过的问题居然没法很肯定地回答出来,实在让自己很恼怒!

      这次让我记忆深刻的一个问题是:

      在mysql中使用聚合函数的时候比如avg(t),t是表中一个类型int型的字段,可为null,有三行数据,三行中的数据分别为:10,null,20,请问最后的结果是什么?

      我的回答是15,在面试结束之后我尝试了一下结果没错,不过我对于聚集函数对null的处理貌似错了,我认为是聚合函数会将null值看作0,找了一番,博客中都认为是忽略null值,因为没有找到官方的说明文档的说明,只好先认同博客中各位牛人所说的啦!如果有人找到了,麻烦给我个地址,感激不尽!

      下面是自己尝试的结果图(注意count函数,这有个特例):


      avg函数:

图一

 

 

图二


        count函数:使用count(*)

图三

 

 

图四

 

         count函数:使用count(xx),即使用特定的字段名

 

图五

 

 

图六

  


         经过自己的测试,在mysql 5.6环境下除了count(*)为特例(不忽略null值)外,其余聚集函数确实是忽略null值(如果大牛们都没错的话)!

原文地址:https://www.cnblogs.com/liaochong/p/sqlavg.html