http://hi.baidu.com/mengjingchao11/item/8f7807d08381cc5bd73aae72
在数据库中有一数据表Student,字段有StudentID,StudentName,ClassID,其中StudentID并不是连续的编号,现在的任务是查询出指定范围内的数据,比如想要查询第五条数据和第十条数据。如果StudentID为连续的编号,那么这个任务会简单些。对于不连续的编号,我们可以使用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即可。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。