MySql数据库基础之分组查询详解

2023年 4月 15日 70.6k 0

目录 1. group by 2. having 1. group by 找出每个工作岗位的工资和? 思路:先按照工作岗位分组,然后对工资进行求和。 mysql select job, sum(sal) from emp group by job; 找出每个部门的最高薪资?思路

目录1. group by2. having

1. group by

找出每个工作岗位的工资和?

思路:先按照工作岗位分组,然后对工资进行求和。

mysql> select job, sum(sal) from emp group by job;

找出每个部门的最高薪资?思路:按照部门编号分组,然后求每一组的最大值

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

找出每个部门,不同工作岗位的最高薪资?思路:将两个字段联合成一个字段看(两个字段分组)

mysql> select deptno, job, max(sal) from emp group by deptno, job;

2. having

可以对分完组之后的数据进一步过滤

having 必须要和 group by 联合使用

找出每个部门最高薪资,要求显示最高薪资大于 3000 的? 第一步:找出每个部门最高薪资,按照部门编号分组,求每一组的最大值 第二步:要求显示最高薪资大于 3000 的

mysql> select deptno, max(sal) from emp group by deptno having max(sal) > 3000;

优化

where 和 having,优先选择 where,不能使用 where 再使用 having

mysql> select deptno, max(sal) from emp where sal > 3000 group by deptno;

到此这篇关于MySql数据库基础之分组查询详解的文章就介绍到这了,更多相关MySql分组查询内容请搜索每日运维以前的文章或继续浏览下面的相关文章希望大家以后多多支持每日运维!

相关文章

Oracle如何使用授予和撤销权限的语法和示例
Awesome Project: 探索 MatrixOrigin 云原生分布式数据库
下载丨66页PDF,云和恩墨技术通讯(2024年7月刊)
社区版oceanbase安装
Oracle 导出CSV工具-sqluldr2
ETL数据集成丨快速将MySQL数据迁移至Doris数据库

发布评论