语法:

ROW_NUMBER ( )
OVER ( [ PARTITION BY value_expression , ... [ n ] ] order_by_clause )

通过语法可以看出 over里有两个参数, partition by 和 order by ,其中partition by是可以不写的,但是order by是必须有的。可能对order by 比较熟悉(就是按什么排序),但 partition by是什么意思呢?partition  的中文解释是:n. 划分,分开;[数] 分割;隔墙;隔离物 vt. [数] 分割;分隔;区分。让我们再结合下面的参数说明和实例很容易就理解它的含义了。

参数:

PARTITION BY value_expression
         将 FROM 子句生成的结果集划入应用了 ROW_NUMBER 函数的分区。 value_expression 指定对结果集进行分区所依据的列。
    如果未指定 PARTITION BY,则此函数将查询结果集的 所有行视为单个组。
order_by_clause
         ORDER BY 子句可确定在特定分区中为行分配唯一 ROW_NUMBER 的顺序。
返回值类型:
bigint(长整型)

以上是对row_number()over()的理论了解,现在开始用例子演示:

先建表(dbo.PeopleInfo):

CREATE TABLE [dbo].[PeopleInfo](
[id] [int] IDENTITY(1,1) NOT NULL,
[name] [nchar](10) COLLATE Chinese_PRC_CI_AS NULL,
[Gender] [nchar](10) COLLATE Chinese_PRC_CI_AS NULL,
[numb] [nchar](10) COLLATE Chinese_PRC_CI_AS NULL,
[phone] [nchar](10) COLLATE Chinese_PRC_CI_AS NULL,
[FenShu] [int] NULL
) ON [PRIMARY]

向表中插入数据:

insert into peopleinfo([name],Gender,numb,phone,fenshu) values ('李欢','男','3223','1365255',80)
insert into peopleinfo([name],Gender,numb,phone,fenshu) values ('李欢','男','322123','1',90)
insert into peopleinfo([name],Gender,numb,phone,fenshu) values ('李名','男','3213112352','13152',56)
insert into peopleinfo([name],Gender,numb,phone,fenshu) values ('李名','女','32132312','13342563',60)
insert into peopleinfo([name],Gender,numb,phone,fenshu) values ('王华','女','3223','1365255',80)

查询出所有插入的数据:

select * from  dbo.PeopleInfo

结果如图:

例子:只用order by 不用 partition by 的sql语句如下:

--不用partition by
select [name],gender,fenshu, row_number() over(order by fenshu desc) as num from dbo.PeopleInfo

结果如图:

例子:用order by 也用 partition by 的sql语句如下:

select [name],gender,fenshu, row_number() over(partition by Gender order by fenshu desc) as num from dbo.PeopleInfo

结果如图:

比较例子一和例子二的结果图很容易就明白partition by的用处了,以例子二为例就是先用partition by把性别【Gender】分成两个区一个男一个女,然后再用order by 把每个区里的分数【fenshu】从大到小排序。

-----------------------------------------------

练习题(用到了前面所讲的cte(with。。。as)知识点可以看看):

--查找出不同性别中分数最高的学生
with temp as
(
select [name],gender,fenshu, row_number() over(partition by Gender order by fenshu desc) as num from dbo.PeopleInfo
)
select * from temp where num = 1

结果如图:

转自:https://www.cnblogs.com/shuangnet/archive/2013/04/12/3016898.html

最新文章

  1. 【商业源码】生日大放送-Newlife商业源码分享
  2. [Head First设计模式]生活中学设计模式——状态模式
  3. storyboard连线容易出现的问题
  4. Spark On Yarn中spark.yarn.jar属性的使用
  5. Java--时间处理
  6. ANDROID_MARS学习笔记_S01原始版_021_MP3PLAYER001_下载mp3文件
  7. Js5中基本类型
  8. 'dependencies.dependency.(groupId:artifactId:type:classifier)' must be unique
  9. fullCalendar:中文API
  10. Sping AOP初级——入门及简单应用
  11. win-zabbix_agent端配置解析
  12. Sql Server 镜像相关
  13. Php7.3 could not find driver
  14. h3c mstp的举例
  15. Python“函数式编程”中常用的函数
  16. Python学习周末练习1-用户登录
  17. CRM创建BP(END USER)
  18. 多线程之 Runnable接口
  19. mysql并行执行--缩短主从同步时延
  20. Redis缓存机制

热门文章

  1. Ionic3 新增 Service
  2. python学习日记(基础数据类型及其方法02)
  3. 自学华为IoT物联网_03 公共事业物联网常见问题及解决方案
  4. ALLOT流控设备操作手册指引
  5. http://bsideup.blogspot.com/2015/04/spring-boot-thrift-part3.html
  6. Lisp经典算法
  7. 解题:SDOI2018 战略游戏
  8. HEOI2019退役总结
  9. 小R的树(权限题)
  10. A1094. The Largest Generation