文章详情页
mysql - 如何在sql语句里写两个不同条件的SUM 并求出二者的差
浏览:214日期:2022-06-12 11:28:33
问题描述
我业务上用的表是用户的积分日志表,字段是用户id,分数类型(加为1减为2),积分,时间戳我需要算出用户每天的总积分是多少我最初是分别sum出加分和减分,然后在后端程序里循环数组求差,这样效率极低,我想在sql语句写出了,怎么写呢?用case then报错
SUM(CASE type=1 THEN `score` ELSE 0-`score`)
问题解答
回答1:应该是:
SUM(IF(type = 1, score, -score))
或者写得啰嗦些:
SUM(CASE WHEN type = 1 THEN score ELSE -score END)
上一条:【mysql】this is incompatible with sql_mode=only_full_group_by下一条:javascript - mysql插入数据时怎样避免与库中的数据重复?
相关文章:
1. mysql插入文本如果是个sql语句就报错了2. css - 如何讓圖片像雲一樣的行為?3. javascript - sublime快键键问题4. javascript - vue中input的blur影响了下拉的点击事件如何解决5. javascript - swiper插件loop模式下的BUG?6. javascript - 微信小程序 如何实现这种左滑动出现删除的办法?有相关api吗?7. python打开.py文件的时候出现window无法打开该文件是怎么回事呢?8. docker 17.03 怎么配置 registry mirror ?9. node.js通过module.exprots返回的是promise对象而非data?10. docker gitlab 如何git clone?
排行榜

网公网安备