mysql - 如何在sql语句里写两个不同条件的SUM 并求出二者的差
本文介绍了mysql - 如何在sql语句里写两个不同条件的SUM 并求出二者的差的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
问 题
我业务上用的表是用户的积分日志表,字段是用户id,分数类型(加为1减为2),积分,时间戳
我需要算出用户每天的总积分是多少
我最初是分别sum出加分和减分,然后在后端程序里循环数组求差,这样效率极低,我想在sql语句写出了,怎么写呢?用case then报错
SUM(CASE type=1 THEN `score` ELSE 0-`score`)
解决方案
应该是:
SUM(IF(type = 1, score, -score))
或者写得啰嗦些:
SUM(CASE WHEN type = 1 THEN score ELSE -score END)
这篇关于mysql - 如何在sql语句里写两个不同条件的SUM 并求出二者的差的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文