SQLSERVER 2005的ROW_NUMBER、RANK、DENSE_RANK的用法
发布时间:2020-12-12 14:45:24 所属栏目:MsSql教程 来源:网络整理
导读:? 来源于:http://www.jb51.net/article/24314.htm ROW_NUMBER() 说明:返回结果集分区内行的序列号,每个分区的第一行从 1 开始。 语法:ROW_NUMBER () OVER ( [ partition_by_clause ] order_by_clause ) 。 备注:ORDER BY 子句可确定在特定分区中为行分
?
来源于:http://www.aspzz.cn/article/24314.htm
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 。 示例: /*以下示例将根据年初至今的销售额,返回 AdventureWorks 中销售人员的 ROW_NUMBER。*/ USE AdventureWorks GO SELECT c.FirstName,c.LastName,ROW_NUMBER() OVER(ORDER BY SalesYTD DESC) AS 'Row Number',s.SalesYTD,a.PostalCode FROM Sales.SalesPerson s JOIN Person.Contact c on s.SalesPersonID = c.ContactID JOIN Person.Address a ON a.AddressID = c.ContactID WHERE TerritoryID IS NOT NULL AND SalesYTD <> 0 /*以下示例将返回行号为 50 到 60(含)的行,并以 OrderDate 排序。*/ select * ????from( ????????select row_number() over (order by orgid) as rownum from org_info ????) as wo where wo.rownumber between 50 and 60 -------------------------------------------------------------- RANK() 说明:返回结果集的分区内每行的排名。行的排名是相关行之前的排名数加一。 语法:RANK () OVER ( [ < partition_by_clause > ] < order_by_clause > ) 备注:如果两个或多个行与一个排名关联,则每个关联行将得到相同的排名。 例如,如果两位顶尖销售员具有同样的 SalesYTD 值,他们将并列第一。 由于已有两行排名在前,所以具有下一个最大 SalesYTD 的销售人员将排名第三。 因此,RANK 函数并不总返回连续整数。 用于整个查询的排序顺序决定了行在结果集中的显示顺序。这也隐含了行在每个分区中的排名。 参数:< partition_by_clause > :将 FROM 子句生成的结果集划分为要应用 RANK 函数的分区。 < order_by_clause >:确定将 RANK 值应用于分区中的行时所基于的顺序。 返回类型:bigint 示例: /*以下示例按照数量对清单中的产品进行了排名。行集按 LocationID 分区,按 Quantity 排序。 USE AdventureWorks; GO SELECT i.ProductID,p.Name,i.LocationID,i.Quantity,RANK() OVER (PARTITION BY i.LocationID order by i.Quantity) as RANK FROM Production.ProductInventory i JOIN Production.Product p ON i.ProductID = p.ProductID ORDER BY p.Name GO SQL code --接上.------------------------------------------------------------------------------------- DENSE_RANK() 说明:返回结果集分区中行的排名,在排名中没有任何间断。行的排名等于所讨论行之前的所有排名数加一。 语法:DENSE_RANK () OVER ( [ < partition_by_clause > ] < order_by_clause > )备注:如果有两个或多个行受同一个分区中排名的约束,则每个约束行将接收相同的排名。?? 例如,如果两位顶尖销售员具有相同的 SalesYTD 值,则他们将并列第一。?? 接下来 SalesYTD 最高的销售人员排名第二。该排名等于该行之前的所有行数加一。?? 因此,DENSE_RANK 函数返回的数字没有间断,并且始终具有连续的排名。??? 整个查询所用的排序顺序确定了各行在结果中的显示顺序。这说明排名第一的行可以不是分区中的第一行。 参数:< partition_by_clause > :将 FROM 子句所生成的结果集划分为数个将应用 DENSE_RANK 函数的分区。??? < order_by_clause >:确定将 DENSE_RANK 值应用于分区中各行的顺序。 返回类型:bigint示例:/*以下示例返回各位置上产品数量的 DENSE_RANK。 */ USE AdventureWorks;GOSELECT i.ProductID,DENSE_RANK() OVER (PARTITION BY i.LocationID order by i.Quantity) as DENSE_RANKFROM Production.ProductInventory i JOIN Production.Product p ON i.ProductID = p.ProductIDORDER BY Name;GO/*ProductID? Name??????????????????????? LocationID Quantity DENSE_RANK ----------- -------------------------------------------------- ---------- -------- -------------------- 1????? Adjustable Race????????????????? 1???? 408?? 571????? Adjustable Race????????????????? 6???? 324?? 521????? Adjustable Race????????????????? 50???? 353?? 82879???? All-Purpose Bike Stand?????????????? 7???? 144?? 34712???? AWC Logo Cap??????????????????? 7???? 288?? 383????? BB Ball Bearing????????????????? 50???? 324?? 743????? BB Ball Bearing????????????????? 6???? 443?? 813????? BB Ball Bearing????????????????? 1???? 585?? 82*/ ------------------------------------------------------------------------------------------------------- 将上面三个函数放在一起计算,更能明显看出各个函数的功能。 CREATE TABLE rankorder(orderid INT,qty INT)INSERT rankorder VALUES(30001,10)INSERT rankorder VALUES(10001,10)INSERT rankorder VALUES(10006,10)INSERT rankorder VALUES(40005,10)INSERT rankorder VALUES(30003,15)INSERT rankorder VALUES(30004,20)INSERT rankorder VALUES(20002,20)INSERT rankorder VALUES(20001,20)INSERT rankorder VALUES(10005,30)INSERT rankorder VALUES(30007,30)INSERT rankorder VALUES(40001,40)INSERT rankorder VALUES(30007,30)GO- -对一个列qty进行的排序 SELECT orderid,qty,??? ROW_NUMBER() OVER(ORDER BY qty) AS rownumber,??? RANK()??? OVER(ORDER BY qty) AS rank,??? DENSE_RANK() OVER(ORDER BY qty) AS denserank FROM rankorderORDER BY qty (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |