加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

Sqlserver使用排名函数Row_Number()函数查询指定范围的数据

发布时间:2020-12-12 13:34:22 所属栏目:MsSql教程 来源:网络整理
导读:Sqlserver使用排名函数Row_Number()函数查询指定范围的数据 http://hi.baidu.com/mengjingchao11/item/8f7807d08381cc5bd73aae72 在数据库中有一数据表Student,字段有StudentID,StudentName,ClassID,其中StudentID并不是连续的编号,现在的任务是查询出

Sqlserver使用排名函数Row_Number()函数查询指定范围的数据


http://hi.baidu.com/mengjingchao11/item/8f7807d08381cc5bd73aae72

在数据库中有一数据表Student,字段有StudentID,StudentName,ClassID,其中StudentID并不是连续的编号,现在的任务是查询出指定范围内的数据,比如想要查询第五条数据和第十条数据。如果StudentID为连续的编号,那么这个任务会简单些。对于不连续的编号,我们可以使用Row_Number函数,使用该函数对数据行进行排序,然后根据生成的排序号对数据进行筛选。

具体的步骤为:

1.首先使用Row_Number函数对数据添加排序

?select?StudentID,StudentName,ClassID,Row_Number()?OVER(Order?by?StudentID)?AS?'RowNumber'

from?Student

注意这里的Row_Number函数必须要有Order?By字段,Partition?By字段可选。这一步完成之后,就会增加一列“RowNumber”,为连续的。

2.使用第一步产生的表作为基表,结合Between..And..函数来完成对指定范围内的数据进行查询

select?*

from(select?StudentID,StudentName,ClassID,Row_Number()?OVER(Order?by?StudentID)?AS?'RowNumber'

??????????from?Student

??????)?as?OrderStudent

where?RowNumber?between?5?and?10

通过这个步骤会查询出经过排名之后的第五到第十(包括第五和第十)条数据。

根据上面的分析,我们可以很容易扩展,假如我要查询每个分组的前N项数据行:使用Row_number的pattition?by字段对数据进行分组,并排名,挑选出每组排名小于N的数据行即可。

具体的SQL语句为:

select?*?from?(select?*,Row_Number()?OVER?(Partiton?By?ClassID?Order?by?StudentID)?as?"RowNumber")?as?OrderedData

where?RowNumber?<N

首先对数据表进行分组并对每一个小组进行排名,然后选择每个小组中排名小于指定的N即可。?

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读