
在实际数据库操作中,我们经常需要根据某个字段的特定值来汇总另一个字段的数据。例如,在一个预订系统中,我们可能需要计算每个员工“已结束”预订的总时长,而不是所有状态预订的总时长。传统的 sum() 函数会汇总所有符合 join 和 where 条件的记录,无法直接实现这种基于行内条件的聚合。
假设我们有以下两张表:
staff 表 (员工信息)
| StaffID | First_name | Last_name |
|---|---|---|
| 1 | John | Doe |
| 2 | Mary | Doe |
booking 表 (预订信息)
| BookingID | StaffID | Status | duration |
|---|---|---|---|
| 1 | 1 | cancelled | 20 |
| 2 | 1 | ended | 20 |
| 3 | 1 | ended | 10 |
| 4 | 2 | cancelled | 30 |
| 5 | 1 | confirmed | 40 |
我们的目标是计算每个员工“已结束 (ended)”预订的总时长。
MySQL 提供了一个强大的 CASE 语句,可以与聚合函数(如 SUM()、COUNT() 等)结合使用,实现复杂的条件逻辑。CASE 语句允许我们在 SELECT 列表中为每一行定义一个条件,并根据条件返回不同的值,然后聚合函数再对这些返回的值进行操作。
其基本语法结构为:
SUM(CASE WHEN condition THEN value_if_true ELSE value_if_false END)
在这个结构中:
为了实现计算每个员工“已结束”预订的总时长,并同时统计“已取消 (cancelled)”预订的数量,我们可以使用以下 SQL 查询:
SELECT
staff.StaffID,
staff.First_name,
staff.Last_name,
SUM(CASE
WHEN booking.Status = 'ended'
THEN booking.duration
ELSE 0
END) AS ended_duration_total, -- 计算已结束预订的总时长
COALESCE(SUM(CASE
WHEN booking.Status = 'cancelled'
THEN 1 -- 对于计数,条件为真时返回1
ELSE 0
END), 0) AS cancelled_bookings_count -- 统计已取消预订的数量
FROM
staff
LEFT JOIN
booking ON staff.StaffID = booking.StaffID -- 假设booking表中StaffID与staff表关联
GROUP BY
staff.StaffID, staff.First_name, staff.Last_name;查询解释:
SELECT staff.StaffID, staff.First_name, staff.Last_name:
SUM(CASE WHEN booking.Status = 'ended' THEN booking.duration ELSE 0 END) AS ended_duration_total:
COALESCE(SUM(CASE WHEN booking.Status = 'cancelled' THEN 1 ELSE 0 END), 0) AS cancelled_bookings_count:
FROM staff LEFT JOIN booking ON staff.StaffID = booking.StaffID:
GROUP BY staff.StaffID, staff.First_name, staff.Last_name:
运行上述查询,将得到类似以下的结果:
| StaffID | First_name | Last_name | ended_duration_total | cancelled_bookings_count |
|---|---|---|---|---|
| 1 | John | Doe | 30 | 1 |
| 2 | Mary | Doe | 0 | 1 |
从结果中可以看出,John Doe 的“已结束”预订总时长为 30 (20 + 10),而 Mary Doe 没有“已结束”预订,所以总时长为 0。同时,两位员工都各有一个“已取消”预订。
通过将 CASE 语句嵌入到 SUM() 等聚合函数中,我们可以实现高度灵活和精确的条件数据聚合。这种技术是处理复杂报表和分析需求的关键工具,能够帮助我们从原始数据中提取更有意义的洞察。掌握 CASE 语句的用法,将显著提升你在 MySQL 中处理数据汇总的能力。
以上就是MySQL 条件求和:使用 CASE 语句实现精确数据汇总的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号