我完全不知道如何在mysql中从rank()(x分区,y by desc)创建一个新列“LoginRank”.

从sql server我将编写以下查询,以创建一个按“登录”分组并按“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修复程序应用于我的数据集,但仍然存在问题.


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

解决方法:

试试这个查询: – 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;

希望它能帮到你!

标签: mysql, rank, partition-by

相关文章推荐

添加新评论,含*的栏目为必填