分组查询
分组查询导图

-
group by 分组语法
select 分组函数,列(要求出现在group by的后面)
from 表
[where 筛选条件]举例选填
group by 分组的列表(也就是按什么条件分组)
order by 子句举例选填
注意:查寻列比较特殊,要求分组函数和group by后面出现的字段 -
分组查询的筛选分两类
数据源 位置 关键字 分组前筛选 原始表 group by子句的前面 where 分组后筛选 分组后的结果表 group by子句的后面 having - 分组函数做条件肯定放在having子句中
- 能用分组前筛选的,就优先考虑使用分组前筛选
-
group by语句支持单个字段分组,多个字段分组(每个字段用逗号隔开,没有顺序要求),表达式或函数
-
也可以添加排序
-
查询每个工种的最高工资
select max(salary),job_id
from employees
group by job_id; -
查询每个位置上的部门个数
select count(*),location_id
from departments
group by location_id; -
查询邮箱中包含A字符的,每个部门的平均工资(添加了筛选条件)
select AVG(salary),department_id
from employees
where email like '%A%'
group by department_id -
查询有奖金的,每个领导手下的最高工资
select max(salary),manager_id
from employees
where commission_pect is not null
group by manager_id
添加了比较复杂的筛选条件
-
查询每个部门的员工个数>2
select count(*) ,department_id(查询每个部门的员工个数)
from employees
where count(*)>2可不能这样进行筛选,因为from employees是针对employees进行筛选,而employees中没有count(*)这个字段,所以这条语句是错误的
group by department_id
having count(*)>2;应该在分组后在进行筛选 -
查询每个工种有奖金的员工的最高工资>12000的工种编号和最高工资
- 先查询每个工种有奖金的员工的最高工资
- 在根据1个查询结果,筛选出最高工资>12000
select max(salary),job_id
from employees
where commission_pect is not null
group by job_id
having max(salary)>12000;
按表达式或函数分组
- 按员工姓名长度分组,查询每一组的员工个数,筛选员工个数>5的有哪些
- 查询每个长度的员工个数
select count(*),length(last_name) as len_name
form employees
group by length(last_name) - 添加筛选条件员工个数>5
having count(*)>5;
- group by和having都支持别名
- 查询每个长度的员工个数
按多个字段分组
- 查询每个部门,每个工种的员工的平均工资
select avg(salary),department_id,job_id
from employees
group by job_id,department_id;调换两个前后顺序也相同
添加排序
- 查询每个部门每个公众的员工的平均工资,并按平均工资从高到低显示
select avg(salary) as a , department_id, job_id
from employees
where department_id is not null
group by job_id,department_id
having a>10000
order by a desc
本文详细解析了SQL分组查询的语法、函数应用及筛选策略,包括单字段和多字段分组,通过实例演示如何查询最高工资、部门人数、特定条件下的平均工资等。同时介绍了分组前筛选(where)与分组后筛选(having)的区别,以及复杂条件下的组合查询方法。
3264

被折叠的 条评论
为什么被折叠?



