zoukankan      html  css  js  c++  java
  • 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值(如果大牛们都没错的话)!

  • 相关阅读:
    python实现满二叉树递归循环
    二叉树遍历规则,先顺遍历/中序遍历/后序遍历
    满二叉树的循环递归
    python 中的super()继承,搜索广度为先
    UITableview 中获取非选中的cell
    iOS——UIButton响应传参数
    iOS- iPad UIPopoverController
    IPAD之分割视图 SplitViewController
    IOS7 隐藏状态栏
    iOS 强制横屏
  • 原文地址:https://www.cnblogs.com/liaochong/p/sqlavg.html
Copyright © 2011-2022 走看看