iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >Row_number()函数用法小结
  • 640
分享到

Row_number()函数用法小结

Row_number()用法Row_number() 2023-05-12 05:05:20 640人浏览 八月长安
摘要

Row_number()函数是SQL Server系统函数中的一种,它为结果集的分区中的每一行分配一个连续的整数。简单的说就是生成一个独表,序号以每个分区的第一行开头,下面是其基本语法: PARTITioN BY子句将

Row_number()函数是SQL Server系统函数中的一种,它为结果集的分区中的每一行分配一个连续的整数。简单的说就是生成一个独表,序号以每个分区的第一行开头,下面是其基本语法:

Row_number()函数用法小结

  • PARTITioN BY子句将结果集划分为分区。 ROW_NUMBER()函数分别应用于每个分区,并重新初始化每个分区的行号。PARTITION BY子句是可选的。如果未指定,ROW_NUMBER()函数会将整个结果集视为单个分区。
  • ORDER BY子句定义结果集的每个分区中的行的逻辑顺序。 ORDER BY子句是必需的,因为ROW_NUMBER()函数对顺序敏感。
  • OVER()是一个开窗函数,对集合进行聚合计算

举个例子,用row_number()函数对以下数据表单进行课程,分数高低及学号排序

Row_number()函数用法小结

sno为学号,cno为所学课程,score为成绩

得到以下语法和查询结果:

Row_number()函数用法小结

可以看到ID的值以cno为分区进行排序,当cno变化时ID也会自动重新开始计数,然后再将成绩以降序排列,这样每科成绩高低及其对应的学号就一目了然。

如果没有partition by则row_number()将整个结果集视为一个分区:

Row_number()函数用法小结

ID的值将一直排到最后。

当row_number()与where一起使用时,可以将row_number()封装成一个子查询,如下只看每科前两名的数据:

Row_number()函数用法小结

将整个函数方法封装命名为a,再从a里面提取需要的条件。

在这里我还要补充一下row_number()函数以外的一个rank()和dense_rank()函数,有时候如果第一名有两个以上的同学时,row_number()函数只会显示一个,而用rank()和dense_rank()则可以全部显示出来(这两个的区别是前者会跳跃排序,后者不会),如图:

Row_number()函数用法小结

到此这篇关于Row_number()函数用法小结的文章就介绍到这了,更多相关Row_number()用法内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: Row_number()函数用法小结

本文链接: https://www.lsjlt.com/news/202072.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作