MySQL统计求和,当SUM遇到CASE WHEN

背景

在MySQL中我们经常会遇到统计求和的情况,但是有些时候我们又不需要分组,只需要分别统计比如type=0type=1 的数量分别是多少,那么我们该如何去做呢?下面整理了一些当SUM 遇到CASE WHEN的情况下的一些统计写法,仅供参考。

解决

sql 复制代码
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;
相关推荐
AAA修煤气灶刘哥5 小时前
后端人速藏!数据库PD建模避坑指南
数据库·后端·mysql
程序新视界6 小时前
学习MySQL绕不开的两个基础概念:聚集索引与非聚集索引
mysql
RestCloud9 小时前
跨境数据传输:ETL如何处理时区与日期格式差异
mysql·api
得物技术12 小时前
MySQL单表为何别超2000万行?揭秘B+树与16KB页的生死博弈|得物技术
数据库·后端·mysql
xiaok13 小时前
mysql中怎么创建一个可控权限数据库账号密码给到开发者
mysql
ByteBlossom16 小时前
MySQL 面试场景题之如何处理 BLOB 和CLOB 数据类型?
数据库·mysql·面试
玉衡子16 小时前
九、MySQL配置参数优化总结
java·mysql
-Xie-17 小时前
Mysql杂志(十六)——缓存池
数据库·mysql·缓存
玉衡子17 小时前
八、MySQL全局优化总结&MySQL8新特性
java·mysql
计算机毕业设计木哥17 小时前
计算机毕设选题推荐:基于Java+SpringBoot物品租赁管理系统【源码+文档+调试】
java·vue.js·spring boot·mysql·spark·毕业设计·课程设计