如何解决DENSE_RANK() - 这里有什么问题?
我有一个非常简单的表格如下:
ID NAME PRICE
1 A 10.45
2 B 8.25
3 A 10.45
4 C 5.00
5 D 4.00
6 E 10.45
运行 DENSE_RANK()
时
select [name],[price],DENSE_RANK() over (PARTITION BY [name],[price] ORDER BY [name],[price]) as drank
from temp
我得到了以下内容。我希望看到第二行应该有 drank
的 2
name price drank
A 10.45 1
A 10.45 1 //this should be 2,isn't
B 8.25 1
C 5.00 1
D 4.00 1
E 10.45 1
解决方法
如果要枚举具有唯一编号的行,请使用 row_number()
:
select [name],[price],row_number() over (PARTITION BY [name],[price] ORDER BY (SELECT NULL)) as drank
from temp;
,
这里的问题是你对排名函数的误解。来自DENSE_RANK (Transact-SQL)
备注
如果同一分区中有两行或更多行具有相同的排名值,则这些行中的每一行都将获得相同的排名。
RANK
也是如此。这意味着,对于您的数据,由于 name
和 price
具有相同的值,因此它们被赋予相同的等级;在这种情况下1
。 这两个函数之间的区别在于它们如何处理相等行之后的行。 DENSE_RANK
将针对每个“新”排名按顺序递增,而 RANK
将跳过存在相等行的排名。 IE。分别为 1,1,2,3 和 1,3,4。
您在这里显然想要的是ROW_NUMBER
。但是,我确实注意到,按相同列进行分区和排序通常也是一个缺陷,因为首先对行进行编号是任意的,并且任意编号每次可能都不相同。理想情况下,您应该按提供明确顺序的另一列进行排序;也许是一个 ID:
SELECT name,price,ROW_NUMBER() OVER (PARTITION BY name,price ORDER BY SomeOtherColumn) AS RN
FROM dbo.YourTable;
如果您没有要排序的列,您可以使用任意值,甚至可以使用 (SELECT NULL)
,就像戈登在他们的回答中所做的那样。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。