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;
相关推荐
zx28596340017 小时前
Laravel5.x版本革新特性全解析
mysql·gateway·智能路由器
shaoming377618 小时前
检查系统硬件配置是否满足PyCharm最低要求
android·spring boot·mysql
czlczl2002092519 小时前
MAX()和MIN()优化
数据库·mysql·性能优化
消失的旧时光-194320 小时前
SQL 第一篇:CRUD 实战,从 user 表开始写接口
数据库·sql·mysql
.小小陈.20 小时前
MySQL 核心基础:数据类型与表约束全解析
数据库·mysql
hERS EOUS21 小时前
MySQL 函数
数据库·mysql
曾几何时`1 天前
MySQL(七)索引
数据库·mysql
悠悠121381 天前
一条 SQL 从敲下回车,到在 MySQL 里“跑完一生”,中间到底经历了啥?
数据库·sql·mysql
秋91 天前
MySQL 9.7.0 使用详解:新特性、实战与避坑指南
android·数据库·mysql
努力努力再努力wz1 天前
【MySQL进阶系列】拒绝冗余SQL:带你透彻理解视图的底层逻辑
android·c语言·数据结构·数据库·c++·sql·mysql