一.SQL Server Row_number函数简介
ROW_NUMBER()
是一个Window函数,它为结果集的分区中的每一行分配一个连续的整数。 行号以每个分区中第一行的行号开头。
以下是ROW_NUMBER()
函数的语法实例:
select *,row_number() over(partition by column1 order by column2) as n from tablename
在上面语法中:
-
PARTITION BY
子句将结果集划分为分区。ROW_NUMBER()
函数分别应用于每个分区,并重新初始化每个分区的行号。PARTITION BY
子句是可选的。如果未指定,ROW_NUMBER()
函数会将整个结果集视为单个分区。 -
ORDER BY
子句定义结果集的每个分区中的行的逻辑顺序。ORDER BY
子句是必需的,因为ROW_NUMBER()
函数对顺序敏感。
二.Row_number函数的具体用法
1.使用row_number()函数进行编号,如:
select ROW_NUMBER() over(order by recordid ) as 编号,* from [dbo].[Basal_Anormal_Solution]
运行结果:
2.对结果集按照指定列进行分组,并在组内按照指定列排序(如:把班级的总分按照小组进行分组显示,分组后在组内进行从高分到低分的排序)
select *,row_number() over(partition by createby order by actionOpeid) as n from [dbo].[Basal_Anormal_Solution]
3.对结果集按照指定列去重(如:对学生成绩按小组进行分组显示,结果集中只显示每组中最高分的学生)
select a.* from (select *,row_number() over(partition by createby order by actionOpeid) as n from [dbo].[Basal_Anormal_Solution])as a where a.n<2