1

我完全难过在 mysql 中从 rank() over(partition by x, order by y desc) 创建一个新列“LoginRank”。

从 sql server 我将编写以下查询,以创建按“login”分组并按“id”排序的列“Loginrank”。

select ds.id, 
       ds.login, 
       rank() over(partition by ds.login order by ds.id asc) as LoginRank
from tablename.ds

我有下表。

create table ds (id int(11), login int(11))
insert into ds (id, login) 
values  (1,1),
    (2,1),
    (3,1),
    (4,2),
    (5,2),
    (6,6),
    (7,6),
    (8,1)   

我尝试将许多现有的 mysql 修复应用到我的数据集,但仍然存在问题。

任何帮助是极大的赞赏。谢谢!

4

3 回答 3

9

试试这个查询: - MySql 不支持 Rank() 函数。

select result.id,result.login,result.rank from (
  SELECT    id,
              login,
              IF(login=@last,@curRank:=@curRank,@curRank:=@_sequence) AS rank,
              @_sequence:=@_sequence+1,
              @last:=login
    FROM      ds , (SELECT @curRank := 1, @_sequence:=1, @last:=0) r
    ORDER BY  id asc) as result;

希望对你有帮助!

于 2017-07-20T04:13:45.013 回答
3

Mysql 8.0以后可以使用Rank函数

 RANK() OVER (
    ORDER BY column_name
) my_rank

RANK() OVER (
PARTITION BY <expression>[{,<expression>...}]
ORDER BY <expression> [ASC|DESC], [{,<expression>...}]
)

这是用法

于 2019-01-02T15:49:25.553 回答
1

尝试这个:

SELECT a.id, a.login, count(b.id)+1 as loginRank
FROM ds a left join ds b ON a.id>b.id AND a.login=b.login
GROUP BY a.id, a.login
ORDER BY a.login, loginRank

你会得到:

id | login | loginRank
 1 |   1   |    1
 2 |   1   |    2
 3 |   1   |    3
 8 |   1   |    4
 4 |   2   |    1
 5 |   2   |    2
 6 |   6   |    1
 7 |   6   |    2
于 2020-04-27T00:00:20.827 回答