Sqlserver的SQL语句实现分页查询
在应用程序的开发中,如果数据库中的数据量过于的庞大,则需要针对查询数据做分页处理,取出对应分页中的数据,在Sqlserver分页的语句写法中,有两种比较常用,一种是数据表中含有自增量Id的情况,可以根据Id的大小顺序进行分页,另一种是数据库中不存在Int类型的Id的情况,此时就需要通过Row_Number函数来实现分页。
(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技术小趣屋。
博主个人技术交流群:960640092,博主微信公众号如下:
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341