Sqlserver的SQL语句实现分页查询
admin
2023-02-08 00:00:10
0

在应用程序的开发中,如果数据库中的数据量过于的庞大,则需要针对查询数据做分页处理,取出对应分页中的数据,在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,博主微信公众号如下:
Sqlserver的SQL语句实现分页查询

相关内容

热门资讯

【第一消息】“衣兆丰悦.有挂吗... 家人们!今天小编来为大家解答衣兆丰悦透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪里买很...
终于懂了“八闽十三水.辅助开挂... 网上科普关于“八闽十三水有没有挂”话题很是火热,小编也是针对八闽十三水作*弊开挂的方法以及开挂对应的...
玩家分享攻略“情怀古诗词.有挂... 有 亲,根据资深记者爆料情怀古诗词是可以开挂的,确实有挂(咨询软件无需打...
【第一财经】“烟台决战麻将.可... 您好:烟台决战麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款...
今日重大消息“微乐掼蛋.辅助器... 今日重大消息“微乐掼蛋.辅助器?”果然有透视挂您好,微乐掼蛋这个游戏其实有挂的,确实是有挂的,需要了...
最新引进“老友内蒙古麻将.到底... 最新引进“老友内蒙古麻将.到底是不是挂?”必胜开挂神器您好,老友内蒙古麻将这个游戏其实有挂的,确实是...
玩家最新攻略“大富豪app.有... 有 亲,根据资深记者爆料大富豪app是可以开挂的,确实有挂(咨询软件无需...
【第一消息】“琼雀海南麻将.怎... 您好:琼雀海南麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款...
【第一消息】“功夫熊猫炸金花.... 您好:功夫熊猫炸金花这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这...
今日重大消息“情怀娱乐.到底有... 今日重大消息“情怀娱乐.到底有挂吗?”太坑了果然有挂您好,情怀娱乐这个游戏其实有挂的,确实是有挂的,...