gpt4 book ai didi

mysql - Rank() 超过 MySQL 中的分区依据

转载 作者:行者123 更新时间:2023-12-01 00:03:37 25 4
gpt4 key购买 nike

我完全无法在 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 修复应用到我的数据集,但问题仍然存在。

非常感谢任何帮助。谢谢!

最佳答案

试试这个查询:- 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() 超过 MySQL 中的分区依据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45204889/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com