GROUP FUNCTION对NULL值的处理

      Group functions ignore null  values in the   column (组函数忽略NULL值)

如下:

SQL> select count(*)   from  employees;

  COUNT(*)

     ----------

       107


SQL> select count(commission_pct)  from employees;

COUNT(COMMISSION_PCT)

            ---------------------

                   35

在employees表中有107行,但非null值的commission_pct列只有35行。


SQL> select avg(commission_pct)  from  employees;

AVG(COMMISSION_PCT)

           -------------------

         .222857143


SQL> select avg(nvl(commission_pct,0))  from  employees;

AVG(NVL(COMMISSION_PCT,0))

        --------------------------

                .072897196

通过对比两次求平均值的结果,可以看出group function在计算时,对null值是丢弃的。

还有个注意点:你不能在where 子句中使用group function,因为where子句先执行。

回答: "Invalid use of group function"是一个错误提示,表示在使用GROUP BY子句时,对于聚合函数的使用有误。在SQL查询中,聚合函数如AVG、SUM、COUNT等通常用于对分组后的数据进行计算。然而,当在HAVING子句中使用聚合函数时,需要注意语法的正确性。通常情况下,HAVING子句应该在GROUP BY子句之后使用,并且只能包含对分组后的结果进行条件限制的表达式。如果在HAVING子句中使用了聚合函数,而没有正确的分组操作,就会出现"Invalid use of group function"的错误提示。因此,需要检查查询语句中的GROUP BY和HAVING子句的使用是否正确,并确保聚合函数的使用符合语法规则。 #### 引用[.reference_title] - *1* [MySQL:Invalid use of group function解决办法](https://blog.csdn.net/Meiko1024/article/details/105663615)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Invalid use of group function解决办法](https://blog.csdn.net/bestforxu/article/details/51131234)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [SQL初学时最常出现的错误(一)Invalid use of group function](https://blog.csdn.net/msqynl311833/article/details/98963040)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值