我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Sqlserver的SQL语句实现分页查询

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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,博主微信公众号如下:
Sqlserver的SQL语句实现分页查询

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Sqlserver的SQL语句实现分页查询

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql分页查询sql语句

使用 mysql 的 limit 和 offset 子句分页:1. 确定每页记录数。2. 计算偏移量:偏移量 = (当前页码 - 1) * 每页记录数。3. 在查询中,使用 limit 子句指定每页记录数,使用 offset 子句指定偏移量
mysql分页查询sql语句
2024-08-02

sql分页查询语句怎么写

SQL分页查询语句可以使用LIMIT关键字来实现。具体语法如下:SELECT 列名FROM 表名LIMIT 开始位置, 查询条数;其中,开始位置表示从第几条记录开始查询,查询条数表示要查询的记录数。例如,如果要查询表"students"中的
2023-08-23

sqlServer实现分页查询的三种方式

目录一、offset /fetch next关键字二、利用max(主键)三、利用row_number关键字总结sqlServer的分页查询和mysql语句不一样,有三种实现方式。分别是:offset /fetch next、利用max(主键
2023-03-02

sql分页查询怎么实现

sql 分页查询的实现什么是分页查询?分页查询是指将大型数据集分割成较小的、易于管理的部分,这些部分称为 "页面"。如何实现 SQL 分页查询在 SQL 中实现分页查询通常使用以下语法:SELECT * FROM table_na
sql分页查询怎么实现
2024-05-30

怎么使用PHP编写分页查询的SQL语句

这篇文章主要讲解了“怎么使用PHP编写分页查询的SQL语句”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用PHP编写分页查询的SQL语句”吧!一、什么是分页查询分页查询是指将一个查询结
2023-07-05

mysql查询语句怎么分页

在 mysql 中使用 limit 和 offset 关键字进行分页,语法为:select * from table_name limit offset, limit。offset 指定跳过的行数,limit 指定检索的行数。示例:limi
mysql查询语句怎么分页
2024-05-30

sqlServer实现分页查询的方式有哪些

今天小编给大家分享一下sqlServer实现分页查询的方式有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。sqlServ
2023-07-05

分享一些实用WordPress SQL查询语句

以下代码来自网络,未经测试,操作数据库有风险,请事先备份 !为所有文章和页面添加自定义字段 这段代码可以为WordPress数据库内所有文章和页面添加一个自定义字段。 你需要做的就是把代码中的‘UniversalCutomFie
2022-06-12

编程热搜

目录