发布时间:2025-12-09 16:30:51 浏览次数:5
ROW_NUMBER()是一个Window函数,它为结果集的分区中的每一行分配一个连续的整数。 行号以每个分区中第一行的行号开头。
语法实例:
select *,row_number() over(partition by column1 order by column2) as nfrom tablename在上面语法中:
示例:
对test_user表的查询结果标记行号,并新增 “编号”列返回
运行结果:
可以看到,查询结果新增了一列,专门用来标记行号。
有了编号,我们就可以方便地进行分页查询了,如何操作,可参考另外篇文章:sqlServer如何实现分页查询
示例:
把test_user表的name按照小组进行分组显示,分组后在组内进行从低到高id排序
运行结果:
示例:
对 test_user表按name进行分组显示,结果集中只显示每组中一条 id最小的数据
运行结果:
查询结果先是经过name分组,然后组内进行id升序排序,组内编号为1的第1条数据,自然就是id最小的数据。
注意:
当我们按成绩分数查询名次等需求时,不能用row_number(),因为如果同班有两个并列第一,row_number()只返回一个结果。这个时候就要用到另外一个函数,rank()和dense_rank()。
rank()和dense_rank()区别:
1、RANK()
在计算排序时,若存在相同位次,会跳过之后的位次。
例如,有3条排在第1位时,排序为:1,1,1,4······
2、DENSE_RANK()
这就是题目中所用到的函数,在计算排序时,若存在相同位次,不会跳过之后的位次。
例如,有3条排在第1位时,排序为:1,1,1,2······