背景
在针对一些数据进行统计汇总的时候,有时会对表中的某些字段进行逻辑运算,如加减乘除,如果要求和的话还可能会用到 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
本篇文章如有帮忙到您,请给「翎野君」点个赞,感谢您的反对。