文章详情页
mysql - 如何在sql语句里写两个不同条件的SUM 并求出二者的差
问题描述
我业务上用的表是用户的积分日志表,字段是用户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. javascript - 关于在angularjs的select中遇到的问题!!2. angular.js - Angular1使用bootstrap轮播条carousel不能自动轮播3. python - 基于scrapy-redis的分布式爬虫运行的时候不能正常运行 遇到的问题如下截图所示4. atom编译器 如何格式化前端代码文件?5. javascript - 关于Js中 this的一道题6. Android Studio 中程序添加不上Xutils 3.0 jar包7. 移动端页面文字垂直居中兼容性问题8. javascript - 求一套有关于IP地址的JS正则!9. css3 - 我的css用less写的,eclipse的jsp文件要修改css很麻烦,怎么解决?10. android - 新建项目卡在Gradle:Resolvedependencies’:app:_debugCompile’
排行榜