ROW_NUMBER()的用法
来源:互联网 发布:巨人网络2016财报 编辑:程序博客网 时间:2024/05/21 08:28
ROW_NUMBER()的用法
版权声明:本文为博主原创文章,未经博主允许不得转载。
今天在博客园上看到一篇关于ROW_NUMBER()的用法,觉得分析的挺透彻,就C过来了,分享一下哈!
ROW_NUMBER()
说明:返回结果集分区内行的序列号,每个分区的第一行从 1 开始。
语法:ROW_NUMBER () OVER ([ <partition_by_clause>]<order_by_clause> ) 。
备注:ORDERBY 子句可确定在特定分区中为行分配唯一 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(ORDERBY SalesYTD DESC) AS'Row Number', s.SalesYTD, a.PostalCode
- FROM Sales.SalesPerson sJOIN Person.Contact con s.SalesPersonID= c.ContactID
- JOIN Person.Address aON a.AddressID= c.ContactID
- WHERE TerritoryIDIS NOTNULL 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 排序。*/
- USE AdventureWorks;
- GO
- WITH OrderedOrdersAS
- (SELECT SalesOrderID, OrderDate,
- ROW_NUMBER() OVER (orderby OrderDate)as RowNumber
- FROM Sales.SalesOrderHeader )
- SELECT *
- FROM OrderedOrders
- WHERE RowNumberbetween 50and 60;
- /*
SalesOrderID OrderDate RowNumber
------------ ----------------------- --------------------
43708 2001-07-03 00:00:00.000 50
43709 2001-07-03 00:00:00.000 51
43710 2001-07-03 00:00:00.000 52
43711 2001-07-04 00:00:00.000 53
43712 2001-07-04 00:00:00.000 54
43713 2001-07-05 00:00:00.000 55
43714 2001-07-05 00:00:00.000 56
43715 2001-07-05 00:00:00.000 57
43716 2001-07-05 00:00:00.000 58
43717 2001-07-05 00:00:00.000 59
43718 2001-07-06 00:00:00.000 60
(11 行受影响)
*/
- ROW_NUMBER()的用法
- ROW_NUMBER的用法
- sql row_number的用法
- ROW_NUMBER()的用法
- ROW_NUMBER()函数的用法
- SQL ROW_NUMBER() 的用法
- ROW_NUMBER()的用法
- ROW_NUMBER、RANK、DENSE_RANK的用法
- ROW_NUMBER、RANK、DENSE_RANK的用法
- row_number() over()的一个用法
- ROW_NUMBER、RANK、DENSE_RANK的用法
- 数据库row_number()的简单用法
- ROW_NUMBER() OVER 的基本用法
- 关于row_number函数的用法
- ROW_NUMBER() OVER函数的基本用法用法
- oracle row_number() 函数的基本用法用法
- ROW_NUMBER() OVER函数的基本用法用法
- ROW_NUMBER() OVER函数的基本用法用法
- (OK)(OK) Install Docker on Fedora 23
- 1.简介
- Java中的继承:父类和子类的关系
- Leetcode Unique Paths
- JavaScript 高级框架设计
- ROW_NUMBER()的用法
- SPAF
- java巩固再看回调函数
- ROW_NUMBER基本用法
- 【codeforces】HDD is Outdated Technology
- FZU-2140-Forever 0.5
- windows 进程通信之管道详解 :
- Fedora 24 安装配置 XX-Net
- PAT-B 1007. 素数对猜想