关于mysql:mysql-sum函数中对两字段做运算时有null时的情况

7次阅读

共计 957 个字符,预计需要花费 3 分钟才能阅读完成。

背景

在针对一些数据进行统计汇总的时候,有时会对表中的某些字段进行逻辑运算,如加减乘除,如果要求和的话还可能会用到 sum 函数,如果两者联合起来应该怎么解决,如果参加运算的字段中呈现 null 值的时候会呈现一些什么状况。

问题

CREATE TABLE `user` (`id` int(10) NOT NULL AUTO_INCREMENT COMMENT '自增 ID',
  `name` varchar(20) NOT NULL COMMENT '名称',
  `total_amount` int(11) DEFAULT NULL COMMENT '账户总金额',
  `freeze_amount` int(11) DEFAULT NULL COMMENT '解冻金额',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci

数据如下

如上表所示,用户信息表中有账户总金额和解冻金额字段,咱们当初想要计算可用金额,依据业务场景可用金额 = total_amount – freeze_amount,如果此时要汇总计算表中所有数据的可用金额总和,咱们能够写如下 SQL。

依据表中的数据,咱们晓得统计后正确的后果应该是

(2000 - 50) + (1500 - 100) + (500 - 50) + 1000 = 4800

但如果咱们这么写,那么失去的后果是谬误的。

select sum(total_amount - freeze_amount) from user
(2000 - 50) + (1500 - 100) + (500 - 50) + (1000 - null) = 3800

因为 1000 – null 的后果不是 1000 而是 null,因为 null 与任何值比拟和运算的后果都是 null,所以咱们应该针对 null 做非凡解决。

须要次要这样写也是没有用的,因为外面 1000-null,依然是一个谬误的后果

select ifnull(sum(total_amount - freeze_amount),0) from user 

正确的写法应该是

select ifnull(sum(total_amount),0) - ifnull(sum(freeze_amount),0) from user

本篇文章如有帮忙到您,请给「翎野君」点个赞,感谢您的反对。

正文完
 0