【MySQL笔记】聚合函数的使用(GROUP BY 与 HAVING)

目录

 

常见的几个聚合函数

计算表中有多少条记录的方法

GROUP BY的使用

HAVING的使用

聚合函数SQL 99语法 

SQL语句的执行过程


常见的几个聚合函数

注:MySQL 中聚合函数不可以嵌套使用

AVG()与 SUM():平均值与求和。只适用于数值类型的字段。公式:AVG = SUM / COUNT

MAX()与 MIN():求最大值与最小值。适用于数值类型,字符串类型,日期时间类型的字段(或变量)

COUNT():计算指定字段在查询结构中出现的个数。注:计算指定字段出现的个数时,是不计算 NULL 值的

计算表中有多少条记录的方法

1. COUNT (*)

2. COUNT (1) #当然 2 也可以,3 也可以,n 也可以,只是我们把每一个字段别名为 1,2,n

3. COUNT (具体字段) #此方法要灵活使用,在有些情况不一定对

如果使用的是 MyISAM 存储引擎,则三者效率相同,都是 O(1)

如果使用的是 InnoDB 存储引擎,则三者效率:COUNT(*)= COUNT(1)> COUNT(字段)

GROUP BY的使用

SELECT 中出现的非组函数的字段必须声明在 GROUP BY 中

反之,GROUP BY 中声明的字段可以不出现在 SELECT 中

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

MySQL 中 GROUP BY 中使用 WITH ROLLUP

注:在使用 ROLLUP 时,不能同时使用 ORDER BY 子句进行结果排序,即 ROLLUP 和 ORDER BY 是互相排斥的

SELECT department_id,AVG(salary)
FROM employees
GROUP BY department_id WITH ROLLUP;
# WITH ROLLUP 会在分组条件的基础上,返回一个总分组,就是所有字段为一个组

HAVING的使用

作用:用来过滤数据

如果过滤条件中使用了聚合函数,则必须使用 HAVING 来替换 WHERE。否则报错

HAVING 必须声明在 GROUP BY 的后面

开发中,我们使用 HAVING 的前提是 SQL 中使用了 GROUP BY

SELECT department_id,MAX(salary)
FROM employees
WHERE department_id IN (10,20,30,40)
GROUP BY department_id
HAVING MAX(salary) > 10000;

当过滤条件中有聚合函数时,则此过滤条件必须声明在 HAVING 中

当过滤条件中没有聚合函数时,则此过滤条件必须声明在 WHERE 或 HAVING 中都可以,但是建议声明在 WHERE 中

 

聚合函数SQL 99语法 

SELECT ...,...,...(存在聚合函数)
FROM ...(LEFT/RIGHT)JOIN ... ON 多表的连接条件
WHERE 不包含聚合函数的过滤条件
GROUP BY ...
HAVING 包含聚类函数的过滤条件
ORDER BY ...,...(ASC/DESC)
LIMIT ...,...;

SQL语句的执行过程

FROM -> ON -> JOIN -> WHERE -> GROUP BY -> HAVING -> SELECT -> DISTINCT -> ORDER BY -> LIMIT

                  

  • 5
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

java小白。。

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值