dense_rank()和rank() 窗口函数 mysql

dense_rank()的语法

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

在这个语法中:

首先,PARTITION BY子句将FROM子句生成的结果集划分为分区。DENSE_RANK()函数应用于每个分区。
其次,ORDER BY 子句指定DENSE_RANK()函数操作的每个分区中的行顺序。
如果分区具有两个或更多具有相同排名值的行,则将为这些行中的每一行分配相同的排名。

与RANK()函数不同,DENSE_RANK()函数始终返回连续的排名值。

测试看:
https://www.begtut.com/mysql/mysql-dense_rank-function.html

rank()函数

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

他们之间的区别

  • 一个是连续的,一个不是连续的;

练习巩固

https://leetcode-cn.com/problems/rank-scores/

posted @ 2022-04-26 15:34  雨同我  阅读(243)  评论(0编辑  收藏  举报