【page】mysql笔记(六) 分组查询

分组查询

语法:
select 分组函数,列(要求出现在group by的后面)
from 表
【where 筛选条件】
group by 分组的列表
【order by 子句】

注意:
查询列表必须特殊,要求是分组函数和group by后出现的字段

一、引入:查询每个部门的平均工资

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

案例1:查询每个工种的最高工资

SELECT
	MAX(salary),job_id
FROM
	employees
GROUP BY
	job_id;

案例2:查询每个位置上的部门个数

SELECT
	COUNT(*),location_id
FROM
	departments
GROUP BY
	location_id;

二、添加筛选条件

案例1:查询邮箱中包含a字符的,每个部门的平均工资

SELECT
	AVG(salary),`department_id`
FROM
	employees
WHERE
	email LIKE '%a%'
GROUP BY
	department_id;

案例2:查询有奖金的每个领导手下员工的最高工资

ELECT
	MAX(salary),manager_id
FROM
	employees
WHERE
	`commission_pct` IS NOT NULL
GROUP BY
	manager_id;

案例3:查询领导编号>102的每个领导手下最低工资>5000的领导编号是哪一个,以及最低工资

①先查询领导编号>102的领导手下最低工资,以及领导编号
②:再查询领导编号>102的每个领导手下最低工资>5000的领导编号是哪一个,以及最低工资
SELECT
	MIN(salary),manager_id
FROM
	employees
WHERE
	manager_id>102
GROUP BY
	manager_id
HAVING
	MIN(salary)>5000;

四、按表达式或者函数分组

案例1:按员工姓名的长度分组,查询每一组的员工个数,筛选员工个数>5的有哪些

SELECT
	COUNT(*) AS 员工个数,LENGTH(last_name) AS 姓名长度
FROM
	employees
GROUP BY
	姓名长度
HAVING
	COUNT(*)>5;

五、按多个字段分组

案例1:查询每个部门每个工种的平均工资

SELECT
	AVG(salary),department_id,job_id
FROM
	employees
GROUP BY
	department_id,job_id;
	#查询的部门号和工种号相等的员工的平均工资

六、添加排序

案例1:查询每个部门每个工种的平均工资,并且按平均公资的高低排序

SELECT
	AVG(salary),department_id,job_id
FROM
	employees
WHERE
	department_id IS NOT NULL
GROUP BY
	department_id,job_id
ORDER BY
	AVG(salary) DESC;
	#查询的部门号和工种号相等的员工的平均工资
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值