mysql——分组查询

本文详细介绍了MySQL中的分组查询,包括基本语法、分组前筛选与分组后筛选的区别、GROUP BY的使用方式以及HAVING子句的应用。通过多个实例,展示了如何查询每个部门的平均工资、每个工种的最高工资、分组后添加复杂筛选条件等操作,还探讨了按表达式和多个字段分组,以及如何在分组查询中添加排序。同时,提供了相关习题以加深理解。
摘要由CSDN通过智能技术生成

#进阶5:分组查询
引入:查询每个部门的平均工资
SELECT AVG(salary) FROM employees;

语法:
    SELECT 分组函数,列(要求出现在GROUP BY 的后面)
    FROM 表名
    WHERE 筛选条件
    GROUP BY 分组列表
    ORDER BY 子句;

注意:1、查询列表是分组函数和GROUP BY后出现的字段

总结:    1、分组查询中的筛选条件可以分为两类
    ①分组前筛选:数据源是原始表,筛选条件放在GROUP BY的前面,使用WHERE关键字进行筛选
    ②分组后筛选:分组后的结果,筛选条件放在GROUP BY后面,使用HAVING关键字进行筛选
    分组函数做条件肯定放在HAVING子句中。
    能用分组前筛选的,优先考虑分组前使用,性能更佳。
    2、GROUP BY支持单个字段分组和多个字段分组,字段间用逗号隔开,无顺序要求,支持表达式和函数
    3、也可以添加排序,放在整个语句后面。
简单分组查询
案例1:查询每个工种的最高工资

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

案例2:查询每个位

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值