SQL2005中row_number()、rank()、dense_rank()、ntile()函数的用法
2018-03-27 13:20
405 查看
ROW_NUMBER
返回结果集分区内行的序列号,每个分区的第一行从 1 开始。
语法:
ROW_NUMBER ( ) OVER ( [ <partition_by_clause> ] <order_by_clause> )
备注:
ORDER BY 子句可确定在特定分区中为行分配唯一 ROW_NUMBER 的顺序。
参数:
<partition_by_clause>
将 FROM 子句生成的结果集划入应用了 ROW_NUMBER 函数的分区。
<order_by_clause>
确定将 ROW_NUMBER 值分配给分区中的行的顺序。
返回类型:
bigint
RANK
返回结果集的分区内每行的排名。行的排名是相关行之前的排名数加一。
语法:
RANK ( ) OVER ( [ < partition_by_clause > ] < order_by_clause > )
备注:
如果两个或多个行与一个排名关联,则每个关联行将得到相同的排名。例如,如果两位顶尖销售员具有同样的 SalesYTD 值,他们将并列第一。由于已有两行排名在前,所以具有下一个最大 SalesYTD 的销售人员将排名第三。因此,RANK 函数并不总返回连续整数。
用于整个查询的排序顺序决定了行在结果集中的显示顺序。这也隐含了行在每个分区中的排名。
参数:
< partition_by_clause >
将 FROM 子句生成的结果集划分为要应用 RANK 函数的分区。
< order_by_clause >
确定将 RANK 值应用于分区中的行时所基于的顺序。
返回类型:
bigint
返回结果集分区内行的序列号,每个分区的第一行从 1 开始。
语法:
ROW_NUMBER ( ) OVER ( [ <partition_by_clause> ] <order_by_clause> )
备注:
ORDER BY 子句可确定在特定分区中为行分配唯一 ROW_NUMBER 的顺序。
参数:
<partition_by_clause>
将 FROM 子句生成的结果集划入应用了 ROW_NUMBER 函数的分区。
<order_by_clause>
确定将 ROW_NUMBER 值分配给分区中的行的顺序。
返回类型:
bigint
RANK
返回结果集的分区内每行的排名。行的排名是相关行之前的排名数加一。
语法:
RANK ( ) OVER ( [ < partition_by_clause > ] < order_by_clause > )
备注:
如果两个或多个行与一个排名关联,则每个关联行将得到相同的排名。例如,如果两位顶尖销售员具有同样的 SalesYTD 值,他们将并列第一。由于已有两行排名在前,所以具有下一个最大 SalesYTD 的销售人员将排名第三。因此,RANK 函数并不总返回连续整数。
用于整个查询的排序顺序决定了行在结果集中的显示顺序。这也隐含了行在每个分区中的排名。
参数:
< partition_by_clause >
将 FROM 子句生成的结果集划分为要应用 RANK 函数的分区。
< order_by_clause >
确定将 RANK 值应用于分区中的行时所基于的顺序。
返回类型:
bigint
相关文章推荐
- SQL2005中row_number( )、rank( )、dense_rank( )、ntile( )函数的用法
- SQL2005中row_number( )、rank( )、dense_rank( )、ntile( )函数的用法(2)
- SQL2005中row_number()、rank()、dense_rank()、ntile()函数的用法
- SQL2005中row_number( )、rank( )、dense_rank( )、ntile( )函数的用法(2)
- SQL2005中row_number( )、rank( )、dense_rank( )、ntile( )函数的用法(2)
- SQL2005中row_number( )、rank( )、dense_rank( )、ntile( )函数的用法(2)
- SQL2005中row_number( )、rank( )、dense_rank( )、ntile( )函数的用法(2)(转)
- SQL2005四个排名函数(row_number、rank、dense_rank和ntile)的比较
- SQL2005四个排名函数(row_number、rank、dense_rank和ntile)的比较
- row_number,rank,dense_rank,ntile排名函数的用法
- 知方可补不足~row_number,rank,dense_rank,ntile排名函数的用法
- SQL2005 四个排名函数(row_number、rank、dense_rank和ntile)的比较
- SQL2005中row_number( )、rank( )、dense_rank( )、ntile( )函数的用法
- SQL2005四个排名函数(row_number、rank、dense_rank和ntile)的比较
- SQL2005四个排名函数(row_number、rank、dense_rank和ntile)的比较
- row_number( )、rank( )、dense_rank( )、ntile( )函数的用法 (SQL2005以上)
- SQL2005中row_number( )、rank( )、dense_rank( )、ntile( )函数的用法
- SQL2005四个排名函数(row_number、rank、dense_rank和ntile)的比较
- SQL2005四个排名函数(row_number、rank、dense_rank和ntile)的比较
- sqlserver 中row_number,rank,dense_rank,ntile排名函数的用法