MySQL分组查询——Groupby

时间: 2023-08-02 admin 互联网

MySQL分组查询——Group  by

MySQL分组查询——Group by

1、Group by:将表中的数据分成若干组

           语法:

                      select   分组函数,列(要求出现在group by的后面)

                      from      表

                      [where  筛选条件]

                      group  by   分组的列表

                      [order  by   子句]

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

           特点:

                      1)分组查询中的筛选条件分为两类

                                                       数据源                          位置                                 关键字

                      分组前筛选               原始表               group by子句的前面                    where

                     分组后筛选        分组后的结果集         group by子句的后面                   having

                     分组函数做条件一定放在having子句中;

                     分组前筛选优先于分组后筛选

                     2)group  by子句支持单个字段分组,多个字段分组(多个字段之间用逗号隔开没有顺序要求),表达式或函数使用较少

                    3)使用group  by子句可以在末尾加上排序子句

2、分组案例练习

           2.1  简单筛选

                    2.1.1  查询每个工种的最高工资

-- 查询每个工种的最高工资
SELECT MAX(salary),job_id
from employees
GROUP BY job_id;

                    2.1.2  查询每个位置上的部门个数

-- 查询每个位置上的部门个数
SELECT COUNT(*),location_id
FROM departments
GROUP BY location_id;

           2.2  分组前筛选

                    2.2.1  查询有奖金的每个领导手下员工的最高工资

-- 查询有奖金的每个领导手下员工的最高工资
SELECT MAX(salary),manager_id
from employees
where commission_pct IS not NULL
GROUP BY manager_id;

                    2.2.2  查询邮箱中包含a字符的每个部门的平均工资

-- 查询邮箱中包含a字符的每个部门的平均工资
SELECT AVG(salary),department_id
FROM employees
WHERE email LIKE '%a%'
GROUP BY department_id;

           2.3  分组后筛选

                    2.3.1  查询每个部门的员工个数>2

-- 查询每个部门的员工个数>2
SELECT COUNT(*),department_id
FROM employees
GROUP BY department_id
HAVING COUNT(*) > 2;

           2.4  按多个字段进行分组

                    2.4.1  查询每个部门每个工种的员工平均工资

-- 查询每个部门每个工种的员工平均工资
SELECT AVG(salary),department_id,job_id
FROM employees
GROUP BY job_id,department_id;

           2.5  按表达式或函数进行分组

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

-- 按员工姓名的长度分组,查询每一组的员工个数,筛选员工个数>5的有哪些
SELECT COUNT(*),LENGTH(last_name) len_name
FROM employees
GROUP BY LENGTH(last_name)
HAVING COUNT(*)>5;-- 可以使用别名
SELECT COUNT(*) c,LENGTH(last_name) len_name
FROM employees
GROUP BY len_name
HAVING c>5;

           2.6  复杂筛选

                    2.6.1  查询每个工种有奖金的员工的最高工资>12000的工种编号和最高工资

-- 查询每个工种有奖金的员工的最高工资>12000的工种编号和最高工资
SELECT MAX(salary),job_id
FROM employees
WHERE commission_pct IS NOT NULL
GROUP BY job_id
HAVING MAX(salary) > 12000;

                    2.6.2  查询每个领导手下的最低工资>5000的领导编号事哪个,以及其最低工资

-- 查询每个领导手下的最低工资>5000的领导编号事哪个,以及其最低工资
SELECT MIN(salary),manager_id
FROM employees
WHERE manager_id >102
GROUP BY manager_id
HAVING MIN(salary) > 5000;