文章详情页
请教一个mysql查询的问题
浏览:124日期:2022-06-15 13:57:16
问题描述
设一个表中记录了用户的积分变动,默认为加
主键用户id变动日期变动数值100012017-01-01 00:00:0010200022017-01-01 04:10:0020300012017-02-01 05:04:00400400012017-02-05 00:00:0010500022017-04-01 00:00:0030而我如果需要查出各用户各时间段的资金变动总和,如下表所示
主键用户id变动日期变动数值变动总和100012017-01-01 00:00:001010200022017-01-01 04:10:002020300012017-02-01 05:04:00400410400012017-02-05 00:00:0010420500022017-04-01 00:00:003050这种sql改如何书写?我用的是mysql5.6,结果集顺序没有要求。
问题解答
回答1:select sum(变动数值) from table where 变动日期 >=yymmdd and 变动日期 <=yymmdd group by 用户id
回答2:这样的需求建议到程序中处理性能会好很多
当然mysql 也可以直接查询出结果
select a.*,sum(b.变动数值) as 变动总和 from table a left join table as b on a.用户id=b.用户id and a.变动日期>=b.变动日期 group by a.主键回答3:
select ccc.* ,if(@lag_uuid = 用户id ,@lag:=@lag+变动数值,@lag:=变动数值) 变动总和, (@lag_uuid := 用户id) lag_uuid
from (SELECT * FROM tbl_ WHERE 1=1 order by 用户id ) ccc,(select @lag:=0,@lag_uuid:=null) tb_lag
order by ccc.id
相关文章:
1. android - 哪位大神知道java后台的api接口的对象传到前端后输入日期报错,是什么情况?求大神指点2. mac里的docker如何命令行开启呢?3. javascript - 如何向localStorage上的数组push数据4. java - 在同一服务器上以不同端口启动两次同一maven项目会出错5. java - C语言的一道算法题-兄弟郊游问题 求解?6. nginx 所有页面指向index.html7. css - jq有无现成函数改变rotateX/Y的deg8. vue添加锚点,实现滚动页面时锚点添加相应的class操作9. 求救一下,用新版的phpstudy,数据库过段时间会消失是什么情况?10. javascript - react-router-dom 跳转问题js
排行榜
