背景
在MySQL中我们经常会遇到统计求和的情况,但是有些时候我们又不需要分组,只需要分别统计比如type=0和type=1的数量分别是多少,那么我们该如何去做呢?下面整理了一些当SUM遇到CASE WHEN的情况下的一些统计写法,仅供参考。
解决
SELECT
-- 统计total_work_hour总和
IFNULL(SUM(total_work_hour), 0) AS totalWorkHour,
-- 统计当robot_type=0的时候的total_work_dist的总和
IFNULL(SUM(CASE WHEN robot_type = 0 THEN total_work_dist ELSE 0 END), 0) AS totalWorkDist,
-- 统计当robot_type=1的时候的total_work_dist的总和
IFNULL(SUM(CASE WHEN robot_type = 1 THEN total_work_dist ELSE 0 END), 0) AS totalWorkDistClean,
-- 统计当online_status=0的时候的记录数量的总和
IFNULL(SUM(CASE WHEN online_status = 0 THEN 1 ELSE 0 END), 0) AS totalOffline,
-- 统计当online_status=1的时候的记录数量的总和
IFNULL(SUM(CASE WHEN online_status = 1 THEN 1 ELSE 0 END), 0) AS totalOnline,
-- 统计bind_time和当前时间相差了几个小时
IFNULL(SUM(TIMESTAMPDIFF(HOUR, bind_time, NOW())), 0) AS totalBindHour,
-- 统计总记录数量
IFNULL(SUM(1), 0) AS totalCount
FROM
device_info;