如何在sql语句里写两个不同条件的SUM 并求出二者的差

我业务上用的表是用户的积分日志表,字段是用户id,分数类型(加为1减为2),积分,时间戳
我需要算出用户每天的总积分是多少
我最初是分别sum出加分和减分,然后在后端程序里循环数组求差,这样效率极低,我想在sql语句写出了,怎么写呢?用case then报错

SUM(CASE type=1 THEN `score` ELSE 0-`score`)
阅读 6k
1 个回答

应该是:

SUM(IF(type = 1, score, -score))

或者写得啰嗦些:

SUM(CASE WHEN type = 1 THEN score ELSE -score END)
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题