mysql 排名

接到一个数据排名需求,查阅资料mysql 8.0 自带排名函数 RANK ,DENSE_RANK ,ROW_NUMBER。令人遗憾的是我们数据库使用的是5.7,只能自己实现排序功能了。

废话不多说,直接撸起来。简易数据如下表

idorder_nouser_idcreate_time
21804281031087355471593310012018-04-28 10:31:20
41804281103140705534856210022018-04-28 11:03:07
61804281741331676966873910032018-04-28 17:41:29
81804281820023069636182610022018-04-28 18:20:25

若想根据创建时间排名倒序,借助伪列即可满足

SELECT
	o.*,
	( @cur_rank := @cur_rank + 1 ) ranking 
FROM
	t_orders o,
	( SELECT @cur_rank := 0 ) r 
ORDER BY
	create_time DESC;

拓展一下,若是根据用户分组之后,组内排名怎么实现呢?如上面原始数据 1002 用户存在2条订单记录,期望的效果是 18042811031407055348562

订单排名为1 18042818200230696361826 订单排名为 2 其他用户只有1条故排名为1即可。其实实现也不难,多声明一个变量搞定

SELECT
	o.*,
CASE
	
	WHEN @prevUser = user_id THEN
	@cur_rank := @cur_rank + 1 
	WHEN @prevUser := user_id THEN
	@cur_rank := 1 
	END AS ranking 
FROM
	t_orders o,
	( SELECT @cur_rank := 0, @prevUser := NULL ) r 
ORDER BY
	user_id DESC,
create_time DESC;

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值