sql 聚合函数对 null 的处理[通俗易懂]

sql 聚合函数对 null 的处理[通俗易懂]聚合函数计数类型(count)SELECTCOUNT(*)FROM(SELECT1ASnumUNIONALLSELECT1ASnumUNIONALLSELECT2ASnumUNIONALLSELECTNULLASnum);SELECTCO

大家好,又见面了,我是你们的朋友全栈君。

聚合函数

计数类型(count)

SELECT  COUNT(*)
FROM    (
            SELECT  1 AS num
            UNION ALL
            SELECT  1 AS num
            UNION ALL
            SELECT  2 AS num
            UNION ALL
            SELECT  NULL AS num
        ) 
;

SELECT  COUNT(num)
FROM    (
            SELECT  1 AS num
            UNION ALL
            SELECT  1 AS num
            UNION ALL
            SELECT  2 AS num
            UNION ALL
            SELECT  NULL AS num
        ) 
;

两个结果分别为 4 和 3

count(*) 和 count(column) 的区别可以看之前写的这个文章

同时 sum(column) 也会直接忽略 null 值

数学函数(方差:var_pop 标准差:stddev 等)

SELECT  var_pop(num)
FROM    (
            SELECT  3 AS num
            UNION ALL
            SELECT  6 AS num
            UNION ALL
            SELECT  9 AS num
            UNION ALL
            SELECT  NULL AS num
        ) 
;

SELECT  stddev(num)
FROM    (
            SELECT  3 AS num
            UNION ALL
            SELECT  6 AS num
            UNION ALL
            SELECT  9 AS num
            UNION ALL
            SELECT  NULL AS num
        ) 
;

两个结果分别为 6.0 和 2.449489742783178

[3 6 9]  的方差为 6 ,标准差为 6 的平方根

两个结果对比可以发现,也是直接忽略 null 值的,并不会把它当做 0 处理

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/151860.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • WP系统推广难的原因之中的一个之我见

    WP系统推广难的原因之中的一个之我见

    2022年1月30日
    56
  • Springboot 整合RabbitMq ,用心看完这一篇就够了

    Springboot 整合RabbitMq ,用心看完这一篇就够了该篇文章内容较多,包括有rabbitMq相关的一些简单理论介绍,provider消息推送实例,consumer消息消费实例,Direct、Topic、Fanout的使用,消息回调、手动确认等。(但是关于rabbitMq的安装,就不介绍了)在安装完rabbitMq后,输入http://ip:15672/,是可以看到一个简单后台管理界面的。在这个界面里面我们可以做些什么?可以手动创建…

    2022年5月15日
    34
  • [CentOS]离线安装gcc/gcc-c++-「建议收藏」

    [CentOS]离线安装gcc/gcc-c++-「建议收藏」环境CentOS7.5官方地址:https://gcc.gnu.org/releases.html镜像站点1:http://mirrors.aliyun.com/centos/7/os/x86_64/Packages/镜像站点2:https://vault.centos.org/7.5.1804/os/x86_64/Packages/gcc:4.8.5安装GCCgcc依赖包清单如下(镜像站下载)cpp-4.8.5-44.el7.x86_64.rpmgcc-4.8.5-44.el7.

    2022年5月9日
    615
  • 台式计算机网线接口松动怎么办,台式电脑网卡坏了怎么修复(图文)「建议收藏」

    台式计算机网线接口松动怎么办,台式电脑网卡坏了怎么修复(图文)「建议收藏」电脑网卡要是坏了,就无法正常上网。网卡对于主机的网络连接来说非常重要,遇到网卡坏了连接不上网络很麻烦,如果重新安装一个或者是拿去修又成本高。有什么好办法可以怎么修复?大家可以参考下文操作。具体方法如下:1、如下图,为电脑网卡外口,即为插网线的地方。2、同事的网卡坏了,没有专业工具,没有配件,怎么办?一些质量差点的网卡或者网卡用的时间长了,里面的金属触片很容易失去弹性。引发接触不良,这时候一种最简单…

    2022年6月26日
    244
  • 猿创征文|点亮JAVA技术之灯(线程篇)「建议收藏」

    猿创征文|点亮JAVA技术之灯(线程篇)「建议收藏」线程安全就是说多线程访问同一段代码,不会产生不确定的结果。又是一个理论的问题,各式各样的答案有很多,我给出一个个人认为解释地最好的:如果你的代码在多线程下执行和在单线程下执行永远都能获得一样的结果,那么你的代码就是线程安全的。(1)不可变像String、Integer、Long这些,都是final类型的类,任何一个线程都改变不了它们的值,要改变除非新创建一个,因此这些不可变对象不需要任何同步手段就可以直接在多线程环境下使用(2)绝对线程安全不管运行时环境如何,调用者都不需要额外的同步措施。……….

    2025年8月23日
    7
  • Mac 下读写NTFS文件

    Mac 下读写NTFS文件MacOS版本:10.11.16 (OSXEICapitan)文章末尾附上小白使用使用方式 1、首先插入需要写入文件的NTFS格式的U盘或移动硬盘2、打开终端,然后执行以下命令,会提示输入密码,输入当前登录账号的密码即可,如果不行请输入root账号的密码sudonano/etc/fstab3、显示如下信息GNUnano2.0.6…

    2022年6月29日
    34

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号