当前位置: 首页 > news >正文

Mysql之聚合函数

Mysql之聚合函数

  • 什么是聚合函数
    • 常见的聚合函数
      • GROUP BY
      • WITH ROLLUP
      • HAVING
      • HAVING与WHERE的对比
    • 总结
    • SQL底层原理

什么是聚合函数

对一组数据进行汇总的函数,但是还是返回一个结果
聚合函数也叫聚集,分组函数

在这里插入图片描述

常见的聚合函数

1.AVG(): 求平均值
2.SUM() :求总值
3.MIN(): 最小值
4.MAX(); 最大值
5.COUNT:返回表中的个数

SUM,COUNT这些函数,会自动过滤掉空值情况
AVG = SUM / COUNT

注意:如果计算表中有几条记录,可以用以下的方式
1.COUNT(1)
2.COUNT(*)
3.COUNT(具体字段) (不一定正确)

说明:count(*)会统计值为 NULL 的行,而 count(列名)不会统计此列为 NULL 值的行

一般来说,三者的效率是COUNT(*) == COUNT(1) > COUNT(具体字段)
后面Mysql优化部分会细讲

GROUP BY

GROUP BY的作用就是,按类分组

SELECT department_id, AVG(salary)
FROM employees
GROUP BY department_id ;

注意:
1.GROUP BY中声明的字段,可以出现在SELECT中

2.GROUP BY声明在FROM后面,WHERE后面,ORDER BY前面,LIMIT前面

WITH ROLLUP

使用 WITH ROLLUP,此函数是对聚合函数进行求和
而在groupby后面还可以加入WITH CUBE和WITH ROLLUP 等关键字
对数据进行汇总。不过这个CUBE在mysql中并不适用。

注意 with rollup是对 group by 后的第一个字段,进行分组求和

ORDER BY不能在rollup中使用,两者为互斥关键字.如果使用,会抛出以下错误:
Error Code:1221. Incorrect usage of CUBE/ROLLUP and ORDER BY。mysql5.7中是不支持的,在8.0以后支持。

HAVING

作用:用来过滤数据
如果在过滤条件中,使用了聚合函数,那么就必须要用HAVING来替换WHERE
HAVING 必须声明在GROUP BY的后面

结论
1.当过滤条件有聚合函数的时候,则必须声明在HAVING中
2.当过滤条件没有聚合函数的时候,则可以声明在HAVING或者WHERE中,
但是建议大家声明在WHERE中

HAVING与WHERE的对比

HAVING的使用范围比WHERE广泛
但是在没有聚合函数的时候,WHERE的效率要高于HAVING

总结

#方式1:
SELECT ...,....,...
FROM ...,...,....
WHERE 多表的连接条件
AND 不包含组函数的过滤条件
GROUP BY ...,...
HAVING 包含组函数的过滤条件
ORDER BY ... ASC/DESC
LIMIT ...,...


#方式2:
SELECT ...,....,...
FROM ... JOIN ...
ON 多表的连接条件
JOIN ...
ON ...
WHERE 不包含组函数的过滤条件
AND/OR 不包含组函数的过滤条件
GROUP BY ...,...
HAVING 包含组函数的过滤条件
ORDER BY ... ASC/DESC
LIMIT ...,...


#其中:
#(1)from:从哪些表中筛选
#(2)on:关联多表查询时,去除笛卡尔积
#(3)where:从表中筛选的条件
#(4)group by:分组依据
#(5)having:在统计结果中再次筛选
#(6)order by:排序
#(7)limit:分页

SELECT表的执行顺序
在这里插入图片描述

SQL底层原理

例如,如果在多表查询的时候

  1. 首先先通过 CROSS JOIN 求笛卡尔积,相当于得到虚拟表 vt(virtual table)1-1;
  2. 通过 ON 进行筛选,在虚拟表 vt1-1 的基础上进行筛选,得到虚拟表 vt1-2;
  3. 添加外部行。如果我们使用的是左连接、右链接或者全连接,就会涉及到外部行,也就是在虚拟 表 vt1-2 的基础上增加外部行,得到虚拟表 vt1-3。 当然如果我们操作的是两张以上的表,还会重复上面的步骤,直到所有

相关文章:

  • C# - Opencv应用(2) 之矩阵Mat使用[矩阵创建、图像显示、像素读取与赋值]
  • ts 联合react 实现ajax的封装,refreshtoken的功能
  • Go语言中获取协程ID
  • [深度学习]卷积神经网络的概念,入门构建(代码实例)
  • 算法笔记-第十章-动态规划2
  • 安全领航,共筑敏捷开发新时代【云驻共创】
  • 六边形架构
  • 驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接
  • zookeperkafka学习
  • Golang Context 的并发安全性探究
  • RFID电网资产全寿命周期管理解决方案
  • html实现计算器源码
  • redis的一些操作
  • 4、FFmpeg命令行操作7
  • kibana 7安装
  • 【Java】java | CacheManager | redisCacheManager
  • 机器学习技术栈—— 概率学基础
  • spring注解
  • CSDN流量卷领取和使用保姆级教程——流量卷,恭喜获得每日任务奖励【1500曝光】可获得新增曝光,阅读转化,点赞转化,新增关注-流量卷,流量卷,流量卷
  • 19.删除链表的倒数第 N 个节点
  • 海运港口股掀涨停潮!回应关税下调利好,有货代称美线舱位爆了
  • 科普|揭秘女性压力性尿失禁的真相
  • 支持企业增强战略敏捷更好发展,上海市领导密集走访外贸外资企业
  • 中国恒大:清盘人向香港高等法院申请撤回股份转让
  • 挖掘机4月销量同比增17.6%,出口增幅创近两年新高
  • 中国科学院院士徐春明不再担任山东石油化工学院校长