SQL数据分页查询的方法
最近学习了一下SQL的分页查询,总结了以下几种方法。
首先建立了一个表,随意插入的一些测试数据,表结构和数据如下图:
现在假设我们要做的是每页5条数据,而现在我们要取第三页的数据。(数据太少,就每页5条了)
方法一:
select top 5 *
from [StuDB].[dbo].[ScoreInfo]
where [SID] not in
(select top 10 [SID]
from [StuDB].[dbo].[ScoreInfo]
order by [SID])
order by [SID]
结果:
此方法是先取出前10条的SID(前两页),排除前10条数据的SID,然后在剩下的数据里面取出前5条数据。
缺点就是它会遍历表中所有数据两次,数据量大时性能不好。
方法二:
select top 5 *
from [StuDB].[dbo].[ScoreInfo]
where [SID]
(select MAX(t.[SID]) from (select top 10 [SID] from [StuDB].[dbo].[ScoreInfo] order by [SID]) t )
order by [SID]
结果:
此方法是先取出前10条数据的SID,然后取出SID的最大值,再从数据里面取出 大于 前10条SID的最大值 的前5条数据。
缺点是性能比较差,和方法一大同小异。
方法三:
select *
from (select *,ROW_NUMBER() over(order by [SID]) ROW_ID from [StuDB].[dbo].[ScoreInfo]) t
where t.[SID] between (5*(3-1)+1) and 5*3
结果:
此方法的特点就是使用 ROW_NUMBER() 函数,这个方法性能比前两种方法要好,只会遍历一次所有的数据。适用于Sql Server 2000之后的版本(不含)。
方法四:
select *
from [StuDB].[dbo].[ScoreInfo]
order by [SID]
offset 5*2 rows fetch next 5 rows only
结果:
此方法适用于Sql Server 2008之后的版本(不含)。
offset 10 rows fetch next 5 rows only 这句代码我的理解是:跳过前面10条数据(前2页)从下一条开始取5条数据。
个人感觉这个方法比使用 ROW_NUMBER() 函数的方法要好(从代码方面来看,代码也少很多),至于性能方面没有做过测试,就不说了。
不过,最后两种方法的性能肯定是远超前面两种方法的,具体的还是看实用。
本篇文章到此结束,如果您有相关技术方面疑问可以联系我们技术人员远程解决,感谢大家支持本站!
我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题
本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 SQL数据分页查询的方法
相关文章
- SQL开发知识:SQL中字符串中包含字符的判断方法
- 在SQL Server中迁移数据的几种方法
- sql server2012附加数据库问题解决方法
- SQL Server中关于基数估计计算预估行数的一些方法探讨
- SQL Server实现显示每个类别最新更新数据的方法
- 一键实现:SQL数据转换到Oracle的神器(sql转oracle工具)
- MySQL中SQL语句的使用方法(mysql中sql语句)
- 使用Oracle导出表结构的SQL语句(oracle导出表结构sql)
- Linux运行 SQL: 获取自动化数据操作能力(linux执行sql)
- 关闭Linux系统中防火墙的方法(关闭linux的防火墙)
- 技巧MySQL:学习高效的SQL技巧(mysql高效sql)
- Oracle SQL实现数据去重的方法(oraclesql去重)
- 深入浅出:使用Redis替代SQL查询(redis实现sql查询)
- 数据合法性使用SQL语句判断MSSQL数据合法性(sql判断mssql)
- 快速高效的MSSQL导入SQL方法,让数据转移无压力。(mssql导入sql)
- SQL Server更改数据值的正确方法(sqlserver更改值)
- SQL数据同步MySQL的详细步骤和注意事项(sql同步mysql)
- MySQL数据库备份还原SQL操作指南(mysql数据还原sql)
- MySQL SQL 平方详解 常见方法与实现方式(mysql中sql中平方)
- Oracle 共享池SQL实现高效管理(oracle共享所sql)
- 构建高性能数据库用 SQL 还是 Redis(用sql还是redis)
- SQL与Redis实现数据的迅速存取(sql与redis)
- 深入探讨MySQL中上下级SQL语句的实现方法(mysql 上下级sql)
- Oracle中借助SQL找寻重复数据的方法(oracle中找重复数据)
- 精通Oracle SQL语法,把握大数据运算之道(oracle_sql语法)
- 用SQL语句实现随机查询数据并不显示错误数据的方法
- phpmyadmin里面导入sql语句格式的大量数据的方法
- SQL语句优化方法30例(推荐)
- SQLServer中用T—SQL命令查询一个数据库中有哪些表的sql语句