SQL -- GROUP BY 基本语法

bash 复制代码
SELECT column1, column2, aggregate_function(column3)
FROM table_name
WHERE condition
GROUP BY column1, column2
ORDER BY column1, column2;

主要用途

GROUP BY用于将结果集按照一个或多个列进行分组,通常与聚合函数(如COUNT、SUM、AVG、MAX、MIN)一起使用。

常用聚合函数

  • COUNT() - 计算行数
  • SUM() - 求和
  • AVG() - 平均值
  • MAX() - 最大值
  • MIN() - 最小值
  • GROUP_CONCAT() - 连接字符串(MySQL)

实际示例

1. 基本分组统计
bash 复制代码
-- 按部门统计员工数量
SELECT department, COUNT(*) as employee_count
FROM employees
GROUP BY department;
2. 多列分组
sql 复制代码
-- 按部门和职位统计
SELECT department, position, COUNT(*) as count
FROM employees
GROUP BY department, position;
3. 使用聚合函数
sql 复制代码
-- 按部门统计平均工资
SELECT department, 
       COUNT(*) as employee_count,
       AVG(salary) as avg_salary,
       MAX(salary) as max_salary,
       MIN(salary) as min_salary
FROM employees
GROUP BY department;
4. 带WHERE条件的分组
sql 复制代码
-- 统计2023年各月份的销售总额
SELECT MONTH(order_date) as month,
       SUM(amount) as total_sales
FROM orders
WHERE YEAR(order_date) = 2023
GROUP BY MONTH(order_date)
ORDER BY month;
5. 使用HAVING过滤分组结果
sql 复制代码
-- 找出平均工资超过50000的部门
SELECT department, AVG(salary) as avg_salary
FROM employees
GROUP BY department
HAVING AVG(salary) > 50000;
6. 复杂分组示例
sql 复制代码
-- 按年份和季度统计销售数据
SELECT 
    YEAR(order_date) as year,
    QUARTER(order_date) as quarter,
    COUNT(*) as order_count,
    SUM(amount) as total_amount,
    AVG(amount) as avg_amount
FROM orders
WHERE order_date >= '2020-01-01'
GROUP BY YEAR(order_date), QUARTER(order_date)
ORDER BY year, quarter;

重要注意事项

1. SELECT子句规则
sql 复制代码
-- ✅ 正确:SELECT中的非聚合列必须在GROUP BY中
SELECT department, COUNT(*)
FROM employees
GROUP BY department;

-- ❌ 错误:name不在GROUP BY中
SELECT department, name, COUNT(*)
FROM employees
GROUP BY department;
2. WHERE vs HAVING (?)
sql 复制代码
-- WHERE:过滤行(在分组前)
SELECT department, COUNT(*)
FROM employees
WHERE salary > 30000
GROUP BY department;

-- HAVING:过滤分组(在分组后)
SELECT department, COUNT(*)
FROM employees
GROUP BY department
HAVING COUNT(*) > 5;
3. 分组排序
sql 复制代码
-- 按分组结果排序
SELECT department, COUNT(*) as emp_count
FROM employees
GROUP BY department
ORDER BY emp_count DESC;

实际应用场景

1. 数据分析
sql 复制代码
-- 用户行为分析:按日期统计访问量
SELECT DATE(visit_time) as date,
       COUNT(DISTINCT user_id) as unique_visitors,
       COUNT(*) as total_visits
FROM user_visits
GROUP BY DATE(visit_time)
ORDER BY date;
2. 报表生成
sql 复制代码
-- 销售报表:按产品类别统计
SELECT category,
       COUNT(*) as product_count,
       SUM(price * quantity) as total_revenue
FROM sales
GROUP BY category
ORDER BY total_revenue DESC;
3. 数据清理
sql 复制代码
-- 查找重复数据
SELECT email, COUNT(*) as count
FROM users
GROUP BY email
HAVING COUNT(*) > 1;

GROUP BY是SQL中非常重要的功能,特别适用于数据分析和报表生成。记住要正确使用WHERE和HAVING,以及确保SELECT子句中的非聚合列都在GROUP BY中。

相关推荐
码农小卡拉2 分钟前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot
怣506 分钟前
MySQL多表连接:全外连接、交叉连接与结果集合并详解
数据库·sql
wjhx27 分钟前
QT中对蓝牙权限的申请,整理一下
java·数据库·qt
冰暮流星38 分钟前
javascript之二重循环练习
开发语言·javascript·数据库
万岳科技系统开发1 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
冉冰学姐1 小时前
SSM智慧社区管理系统jby69(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·管理系统·智慧社区·ssm 框架
杨超越luckly1 小时前
HTML应用指南:利用GET请求获取中国500强企业名单,揭秘企业增长、分化与转型的新常态
前端·数据库·html·可视化·中国500强
Elastic 中国社区官方博客2 小时前
Elasticsearch:Workflows 介绍 - 9.3
大数据·数据库·人工智能·elasticsearch·ai·全文检索
仍然.2 小时前
MYSQL--- 聚合查询,分组查询和联合查询
数据库
一 乐2 小时前
校园二手交易|基于springboot + vue校园二手交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端