接到一个数据排名需求,查阅资料mysql 8.0 自带排名函数 RANK ,DENSE_RANK ,ROW_NUMBER。令人遗憾的是我们数据库使用的是5.7,只能自己实现排序功能了。
废话不多说,直接撸起来。简易数据如下表
id | order_no | user_id | create_time |
2 | 18042810310873554715933 | 1001 | 2018-04-28 10:31:20 |
4 | 18042811031407055348562 | 1002 | 2018-04-28 11:03:07 |
6 | 18042817413316769668739 | 1003 | 2018-04-28 17:41:29 |
8 | 18042818200230696361826 | 1002 | 2018-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;