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