温馨提示×

SQL DENSE_RANK和ROW_NUMBER比较

sql
小樊
88
2024-08-06 01:12:11
栏目: 云计算

在SQL中,DENSE_RANK和ROW_NUMBER是用来对查询结果进行排名的两种窗口函数,它们的主要区别在于对重复值的处理方式和返回结果的不同。

  1. ROW_NUMBER函数: ROW_NUMBER函数会给每一行分配一个唯一的连续排名,不管有没有重复值。如果有重复值,则每个重复值的排名都会不同。

示例:

SELECT id, name, ROW_NUMBER() OVER (ORDER BY id) AS row_num
FROM table_name;
  1. DENSE_RANK函数: DENSE_RANK函数也会给每一行分配一个排名,但是不同的是,如果有重复值,它会跳过重复的排名,保证排名的连续性。换句话说,相同的值会有相同的排名。

示例:

SELECT id, name, DENSE_RANK() OVER (ORDER BY id) AS dense_rank
FROM table_name;

综上所述,ROW_NUMBER和DENSE_RANK的区别主要在于对重复值的处理方式,如果需要保持排名的连续性且跳过重复值,可以使用DENSE_RANK函数;如果需要每行都有唯一的排名,无论有没有重复值,可以使用ROW_NUMBER函数。

0