时间:2023-10-27来源:系统城装机大师作者:佚名
Row_number()函数是SQL SERVER系统函数中的一种,它为结果集的分区中的每一行分配一个连续的整数。简单的说就是生成一个独表,序号以每个分区的第一行开头,下面是其基本语法:
举个例子,用row_number()函数对以下数据表单进行课程,分数高低及学号排序
sno为学号,cno为所学课程,score为成绩
得到以下语法和查询结果:
可以看到ID的值以cno为分区进行排序,当cno变化时ID也会自动重新开始计数,然后再将成绩以降序排列,这样每科成绩高低及其对应的学号就一目了然。
如果没有partition by则row_number()将整个结果集视为一个分区:
ID的值将一直排到最后。
当row_number()与where一起使用时,可以将row_number()封装成一个子查询,如下只看每科前两名的数据:
将整个函数方法封装命名为a,再从a里面提取需要的条件。
在这里我还要补充一下row_number()函数以外的一个rank()和dense_rank()函数,有时候如果第一名有两个以上的同学时,row_number()函数只会显示一个,而用rank()和dense_rank()则可以全部显示出来(这两个的区别是前者会跳跃排序,后者不会),如图:
到此这篇关于Row_number()函数用法小结的文章就介绍到这了
2023-10-27
windows11安装SQL server数据库报错等待数据库引擎恢复句柄失败解决办法2023-10-27
SQL Server截取字符串函数操作常见方法2023-10-27
浅谈SELECT *会导致查询效率低的原因收缩数据文件通过将数据页从文件末尾移动到更靠近文件开头的未占用的空间来恢复空间,在文件末尾创建足够的空间后,可取消对文件末尾的数据页的分配并将它们返回给文件系统,本文给大家介绍SQL Server 数据库中的收缩数据...
2023-10-27