SQL中的聚合函数使用总结

SQL中的聚合函数使用总结一般在书写sql的是时候很多时候会误将聚合函数放到where后面作为条件查询,事实证明这样是无法执行的,执行会报【此处不允许使用聚合函数】异常。为什么会报异常呢?其原因很简单:having放在groupby的后面 groupby后面只能放非聚合函数的列 where子句的作用是在对查询结果进行分组前,将不符合where条件的行去掉,即在分组之前过滤数据,条件中不能包含聚组函数,使…

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

一般在书写sql的是时候很多时候会误将聚合函数放到where后面作为条件查询,事实证明这样是无法执行的,执行会报【此处不允许使用聚合函数】异常。为什么会报异常呢?其原因很简单:

  • having放在group by 的后面
  • group by 后面只能放非聚合函数的列
  • where 子句的作用是在对查询结果进行分组前,将不符合where条件的行去掉,即在分组之前过滤数据,条件中不能包含聚组函数,使用where条件显示特定的行。
  • having 子句的作用是筛选满足条件的组,即在分组之后过滤数据,条件中经常包含聚组函数,使用having 条件显示特定的组,也可以使用多个分组标准进行分组。

那聚合函数在什么情况下使用或者应该处在sql文中的哪个位置呢
聚合函数只能在以下位置作为表达式使用:

  • select 语句的选择列表(子查询或外部查询);
  •  compute 或 compute by 子句;
  • having 子句;

其实在诸多实际运用中,聚合函数更多的是辅助group by 使用,但是只要我们牢记where的作用对象只是行,只是用来过滤数据作为条件使用。

常见的几个聚合函数

  • 求个数:count
  • 求总和:sum
  • 求最大值:max
  • 求最小值:min
  • 求平均值:avg

当然还有其他类型的聚合函数,可能随着对应sql server不同,支持的种类也不一样。

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

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

(0)
上一篇 2022年6月21日 下午2:36
下一篇 2022年6月21日 下午2:36


相关推荐

  • ubuntu 卸载命令_Ubuntu怎么卸载

    ubuntu 卸载命令_Ubuntu怎么卸载前言本文重点介绍Ubuntu卸载软件的4种方法。他们分别是图形化界面的synaptic、自动解决依赖关系的apt-get,处理依赖关系更强大的aptitude,还有安装本地deb包的dpkg。方法一:Ubuntu使用synaptic图形化界面管理软件oucanrong@zcwyou:~$sudoapt-getinstallsynaptic-y以下是使用Synaptic管理软件的教程。输…

    2026年4月16日
    3
  • python绘制笛卡尔心形曲线_绘制笛卡尔心形曲线

    python绘制笛卡尔心形曲线_绘制笛卡尔心形曲线js 绘制 canvas 图形 varcr document getElementBy cardioid varW cr width 2 H cr height 3 R 150 varc cr getContext 2d varG 360 g 0 T Math PI 2 t T G c save c translate W

    2026年3月19日
    2
  • 一致性hash算法java_一致性hash和普通hash

    一致性hash算法java_一致性hash和普通hash一致性hash算法(consistenthashing)张亮consistenthashing算法早在1997年就在论文Consistenthashingandrandomtrees中被提出,目前在cache系统中应用越来越广泛;1基本场景比如你有N个cache服务器(后面简称c

    2022年10月5日
    3
  • 数据库添加字段sql语句

    数据库添加字段sql语句在咱们平时开发的时候 很容易遇到这种状况 就是在开发的时候 有的需求可能会拓展咱们数据库中的表 好比添加字段什么的 下面就是添加字段的 sql 语句 sql 添加一个字段 数据库 altertable 表名 add 字段名 varchar 32 comment 备注名 开发这样就会在你的表中添加一个字段了 table 若是是一次添加多个字段的话 sql 语句 altertable 表名 add 字段名 varchar 32 comment 备注名 add 字段名 varchar 32 comment 备

    2026年3月18日
    2
  • 汇编语言 寄存器、英文缩写全称

    汇编语言 寄存器、英文缩写全称转载来源 http blog csdn net wxqian25 article details AH amp AL AX accumulator 累加寄存器 BH amp BL BX base 基址寄存器 CH amp CL CX count 计数寄存器 DH amp DL DX data 数据寄存器 SP StackPointer 堆栈指针寄存器 BP BasePointer 基址

    2026年3月18日
    2
  • 海量数据处理的方法总结

    海量数据处理的方法总结

    2021年10月5日
    48

发表回复

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

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