在mysql中的分区上排名()教程

2019-09-25 21:15:11

我完全不知道如何在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;

希望它能帮到你!

当前页面是本站的「Baidu MIP」版。发表评论请点击:完整版 »