天天看点

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>...}]
) 
           

他们之间的区别

dense_rank()和rank() 窗口函数 mysql
  • 一个是连续的,一个不是连续的;

练习巩固

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