SQL DENSE_RANK和ROW_NUMBER比较

avatar
作者
筋斗云
阅读量:0

在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函数。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!