SQL中row_number()rank()dense_rank()ntile()函数详解.doc

SQL中row_number()rank()dense_rank()ntile()函数详解.doc

  1. 1、本文档共11页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
SQL中row_number()rank()dense_rank()ntile()函数详解

row_number( )、rank( )、dense_rank( )、ntile( )函数 SQL 几个新的排序(排名)函数,如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。*/USEAdventureWorksGOSELECT 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 98027 Gail Erickson 2 5015682.3752 98055 Maciej Dusza 3 4557045.0459 98027 Linda Ecoffey 4 3857163.6332 98027 Mark Erickson 5 3827950.238 98055 Terry Eminhizer 6 3587378.4257 98055 Michael Emanuel 7 3189356.2465 98055 Jauna Elson 8 3018725.4858 98055 Carol Elliott 9 2811012.7151 98027 Janeth Esteves 10 2241204.0424 98055 Martha Espinoza 11 1931620.1835 98055 Carla Eldridge 12 1764938.9859 98027 Twanna Evans 13 1758385.926 98055 (13 行受影响)*//*以下示例将返回行号为 50 到 60(含)的行,并以 OrderDate 排序。*/USEAdventureWorks;GOWITH OrderedOrders AS (SELECT SalesOrderID, OrderDate, ROW_NUMBER() OVER (order by OrderDate)as RowNumberFROMSales.SalesOrderHeader ) SELECT *FROM OrderedOrders WHERE RowNumber between 50 and 60;/* S

文档评论(0)

haihang2017 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档