经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MS SQL Server » 查看文章
SQL Server排名或排序的函数
来源:cnblogs  作者:__浮沉丶若轩◇  时间:2019/1/16 9:15:24  对本文有异议
SQL Server获得排名或排序的函数有如下几种:
1、Rank():在结果集中每一条记录所在的排名位置,但排名可能不连续,例如:若同一组内有两个第一名,则该组内下一个名次直接跳至第三名
 
  1. select *,Rank() over (partition by modifieddate order by locationid ) as Rank from Production.ProductInventory 

 

2、Dense_Rank():功能与Rank相似,但排名的数值是连续的,例如:若同一组内有两个第一名,则该组内下一个名次为第二名

 

  1. select *,dense_Rank() over (partition by modifieddate order by locationid ) as Rank from Production.ProductInventory

 

3、Row_Number():根据组显示每一条记录在该组中出现的位置,例如:若有两个第一名,则这两个第一名在一组内排名为1、2,下一组的排序仍从1开始,依次类推

 

  1. select *,row_number() over (partition by productid order by productid ) as Rank from Production.ProductInventory

 

4、NTILE():根据指定的分组数量将结果集分区,并记录其在组中的位置。可以对结果集的数据排序后,按照指定的数量把结果集分成N组,并给予每组一个组编号,分组的方式很简单,将结果集的总记录数除以N,若有余数M,则前M组都多增一条记录,因此,并非所有的组都有相同的记录数,但多记录的组最多只有一条记录。

  1. select top 13 *,NTILE(2) over (partition by productid order by locationid ) as Rank from Production.ProductInventory

 

上述四个函数语法格式相同,都要搭配OVER子句,而且要以指定切分或排序记录的方式,OVER子句定议格式如下:
Over(【Partition BY <提供数值的描述方式>】 ORDER BY <字段> [DES|ASC])
Partition BY 子句决定排名记录的分组方式,而Order By 子句决定每一组记录要如何排序,如果省略了Partition by 子句,则全部记录为一组

 

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号