文章详情页
mysql - 如何在sql语句里写两个不同条件的SUM 并求出二者的差
浏览:111日期: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. dockerfile - 为什么docker容器启动不了?2. 热切期待朱老师的回复,网页视频在线播放器插件配置错误3. apache - 本地搭建wordpress权限问题4. macos - mac下docker如何设置代理5. Android下,rxJava+retrofit 并发上传文件和串行上传文件的效率为什么差不多?6. javascript - web网页版app返回上一页按钮在ios设备失效怎么办?安卓上可以,代码如下,请大神帮助,万分感谢。7. java - Spring Mvc全局异常处理器@ControllerAdvice不起作用?8. css3 - transition属性当鼠标一开的时候设置的时间不起作用9. Whitelabel错误页面发生意外错误(类型=未找到,状态= 404)/WEB-INF/views/home.jsp10. angular.js - ng-grid 和tabset一起用时,grid width默认特别小
排行榜
