当前位置: 代码迷 >> Sql Server >> row_number()是什么意思呀?该如何处理
  详细解决方案

row_number()是什么意思呀?该如何处理

热度:207   发布时间:2016-04-27 12:52:48.0
row_number()是什么意思呀?
row_number() over(partition by X order by Y )
这些是什么意思呀?
谁能帮忙释疑?

------解决方案--------------------
SQL code
ROW_NUMBER、RANK、DENSE_RANK的用法(爱新觉罗.毓华  2007-12-16  广东深圳)SQL Server 2005 引入几个新的排序(排名)函数,如ROW_NUMBER、RANK、DENSE_RANK等。这些新函数使您可以有效地分析数据以及向查询的结果行提供排序值。 --------------------------------------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 AdventureWorksGOSELECT c.FirstName, c.LastName, ROW_NUMBER() OVER(ORDER BY SalesYTD DESC) AS 'Row Number', s.SalesYTD, a.PostalCodeFROM Sales.SalesPerson s JOIN Person.Contact c on s.SalesPersonID = c.ContactIDJOIN Person.Address a ON a.AddressID = c.ContactIDWHERE TerritoryID IS NOT NULL AND SalesYTD <> 0/*FirstName  LastName    Row Number  SalesYTD      PostalCode---------  ----------  ----------  ------------  ----------------------------Shelley    Dyck        1           5200475.2313  98027Gail       Erickson    2           5015682.3752  98055Maciej     Dusza       3           4557045.0459  98027Linda      Ecoffey     4           3857163.6332  98027Mark       Erickson    5           3827950.238   98055Terry      Eminhizer   6           3587378.4257  98055Michael    Emanuel     7           3189356.2465  98055Jauna      Elson       8           3018725.4858  98055Carol      Elliott     9           2811012.7151  98027Janeth     Esteves     10          2241204.0424  98055Martha     Espinoza    11          1931620.1835  98055Carla      Eldridge    12          1764938.9859  98027Twanna     Evans       13          1758385.926   98055(13 行受影响)*/ /*以下示例将返回行号为 50 到 60(含)的行,并以 OrderDate 排序。*/ USE AdventureWorks;GOWITH OrderedOrders AS(SELECT SalesOrderID, OrderDate,ROW_NUMBER() OVER (order by OrderDate)as RowNumberFROM Sales.SalesOrderHeader ) SELECT * FROM OrderedOrders WHERE RowNumber between 50 and 60;/*SalesOrderID OrderDate               RowNumber------------ ----------------------- --------------------43708        2001-07-03 00:00:00.000 5043709        2001-07-03 00:00:00.000 5143710        2001-07-03 00:00:00.000 5243711        2001-07-04 00:00:00.000 5343712        2001-07-04 00:00:00.000 5443713        2001-07-05 00:00:00.000 5543714        2001-07-05 00:00:00.000 5643715        2001-07-05 00:00:00.000 5743716        2001-07-05 00:00:00.000 5843717        2001-07-05 00:00:00.000 5943718        2001-07-06 00:00:00.000 60(11 行受影响)*/--------------------------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;GOSELECT i.ProductID, p.Name, i.LocationID, i.Quantity, RANK() OVER (PARTITION BY i.LocationID order by i.Quantity) as RANKFROM Production.ProductInventory i JOIN Production.Product p ON i.ProductID = p.ProductIDORDER BY p.NameGO/*ProductID   Name                                               LocationID Quantity RANK----------- -------------------------------------------------- ---------- -------- --------------------1           Adjustable Race                                    6          324      711           Adjustable Race                                    1          408      781           Adjustable Race                                    50         353      1172           Bearing Ball                                       6          318      672           Bearing Ball                                       1          427      852           Bearing Ball                                       50         364      1223           BB Ball Bearing                                    50         324      1063           BB Ball Bearing                                    1          585      1103           BB Ball Bearing                                    6          443      1154           Headset Ball Bearings                              1          512      994           Headset Ball Bearings                              6          422      1084           Headset Ball Bearings                              50         388      140316         Blade                                              10         388      33......(1069 行受影响)*/
  相关解决方案