(1)数据表中存在自增量ID的情况
假设我们查询的表名称为Student,包含的字段有:ID(ID号,自增变量)、name(姓名)、BirthDay(出生日期)。按出生日期从早到晚排序,获取排序后第31到60个学生的信息,语句可以使用Select top的方式书写。具体如下:
Select top 30 * FROM Student Where ID Not In (Select top 30 FROM Student Order By BirthDay) Order By BirthDay
如果是获取第91到120排位的学生的话,则是下列语句。
Select top 30 * FROM Student Where ID Not In (Select top 90 FROM Student Order By BirthDay) Order By BirthDay
(2)数据表中不存在ID的情况
此种情况不可能再使用top来排序了,可使用row_Number进行排序后再筛选对应的值。
更改上述的Student表的结构为:StudentCode(文本类型,非数字)、name(姓名)、BirthDay(出生日期)。按出生日期从早到晚排序,获取排序后第31到60个学生的信息,此时的SQL语句为:
With tempTb AS
(
Select ROW_NUMBER() OVER(order by BirthDay ASC) AS RowNumber, FROM Student
)
Select FROM tempTb Where RowNumber>30 AND RowNumber<=60
在临时表tempTb中使用了ROW_NUMBER() OVER来获取排序后的序号,Over里面为排序的规则。
备注:此文章最早发表于博主个人站,原文链接Sqlserver的SQL语句实现分页查询_IT技术小趣屋。
总结以上是内存溢出为你收集整理的Sqlserver的SQL语句实现分页查询全部内容,希望文章能够帮你解决Sqlserver的SQL语句实现分页查询所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)