【转载】Sqlserver的SQL语句实现分页查询

本文介绍了在SQLServer中实现分页查询的两种方法:一种适用于含有自增量Id的数据表,通过SelectTop语句实现;另一种适用于无Id的数据表,利用Row_Number函数完成分页。文章提供了具体的SQL语句实例,帮助开发者高效处理大量数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

转载地址如下。1


  1. https://www.cnblogs.com/xu-yi/p/10446922.html ↩︎

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值