MySQL聚合统计

【数据库】MySQL聚合统计

王笃笃-CSDN博客https://blog.csdn.net/wangduduniubi?type=blog显示平均工资低于2000的部门和它的平均工资

mysql> select deptno,avg(sal) deptavg from emp group by deptno;

+--------+-------------+

| deptno | deptavg |

+--------+-------------+

| 20 | 2175.000000 |

| 30 | 1566.666667 |

| 10 | 2916.666667 |

+--------+-------------+

3 rows in set (0.01 sec)

mysql> select deptno,avg(sal) deptavg from emp group by deptno havingdeptavg<2000;

+--------+-------------+

| deptno | deptavg |

+--------+-------------+

| 30 | 1566.666667 |

+--------+-------------+

having对聚合后的数据进行条件筛选。

having 和 where 的区别

条件筛选的阶段不同

mysql> select deptno,job,avg(sal) myavg from emp where ename != 'SMITH' group by deptno,job having myavg<2000;

+--------+----------+-------------+

| deptno | job | myavg |

+--------+----------+-------------+

| 30 | SALESMAN | 1400.000000 |

| 20 | CLERK | 1100.000000 |

| 30 | CLERK | 950.000000 |

| 10 | CLERK | 1300.000000 |

+--------+----------+-------------+

where

对具体的任意列进行条件筛选

having

对分组聚合之后的结果进行条件筛选。

条件筛选的阶段不同

1

from emp

2

where ename != 'SMITH'

3

group by deptno,job

4

deptno,job,avg(sal) myavg

5

having myavg<2000;

中间筛选出来的和最终结果------>全部可以看做是逻辑上的表-->mysql 中一切皆表

相关推荐
码农阿豪7 分钟前
兼容是基石,超越是未来:金仓数据库的三重革新
数据库
中年程序员一枚8 分钟前
Python防止重复资源的链接mysql方法
开发语言·python·mysql
廋到被风吹走11 分钟前
【数据库】【Redis】基本概念和特点
数据库·redis·缓存
榮十一11 分钟前
10道SQL练习题及答案
数据库·sql·算法
Hns.18 分钟前
MySQL慢SQL问题查找与优化方案
数据库·sql·mysql
一水鉴天20 分钟前
整体设计 定稿 之6 完整设计文档讨论及定稿 之3 整体设计原则(原型-过程-模块三阶联动体系)
前端·数据库·人工智能
管理大亨26 分钟前
企业级ELK:从日志收集到业务驱动
java·大数据·网络·数据库·elk·elasticsearch
KaiwuDB34 分钟前
从 0 到 1 的交互式课程平台—— KWDB Playground
数据库
yingjuxia菜鸟com40 分钟前
Vue Vuex详解,一文彻底搞懂Vuex
数据库·人工智能
菜择贰42 分钟前
ubantu下载mysql
数据库·mysql·adb