不同数据库的分页查询实现方法总结

数据库
本文以一个实例的方式对SQL Server、Oracle和MySQL数据库中实现分页查询的方法进行了介绍,希望能够对您有所帮助。

分页查询数据库查询中经常用到的一项操作,对查询出来的结果进行分页查询可以方便浏览。那么Oracle、SQL Server、MySQL是如何实现查询的呢?本文我们就来介绍这一部分内容。

首先我们先看一下SQL Server 数据库中SQL语句查询分页数据的解决方案:

实例:要求选取tbllendlist中第3000页的记录,每一页100条记录。

方法1:

 

  1. select top 100 * from tbllendlist     
  2.  
  3. where fldserialNo not in    
  4.  
  5. (    
  6.  
  7. select top 300100 fldserialNo from tbllendlist     
  8.  
  9. order by fldserialNo    
  10.  
  11. )    
  12.  
  13. order by fldserialNo  

 

方法2:

 

  1. SELECT TOP 100 *     
  2.  
  3. FROM tbllendlist     
  4.  
  5. WHERE (fldserialNo >     
  6.  
  7. (SELECT MAX(fldserialNo)     
  8.  
  9. FROM (SELECT TOP 300100 fldserialNo     
  10.  
  11. FROM tbllendlist     
  12.  
  13. ORDER BY fldserialNo) AS T))     
  14.  
  15. ORDER BY fldserialNo  

 

方法1执行速度比较快!

SQL Server数据库

从数据库表中的第M条记录开始取N条记录,利用Top关键字:注意如果Select语句中既有top,又有order by,则是从排序好的结果集中选择:

 

  1. SELECT *  
  2.  
  3. FROM  ( SELECT Top N *  
  4.  
  5. FROM    (SELECT Top (M + N - 1) * FROM 表名称 Order by 主键 desc) t1 ) t2  
  6.  
  7. Order by 主键 asc 

 

例如从表Sys_option(主键为sys_id)中从10条记录还是检索20条记录,语句如下:

 

  1. SELECT *  
  2.  
  3. FROM ( SELECT TOP 20 *  
  4.  
  5. FROM (SELECT TOP 29 * FROM Sys_option order by sys_id desc) t1) t2  
  6.  
  7. Order by sys_id asc 

 

Oracle数据库

从数据库表中第M条记录开始检索N条记录

 

  1. SELECT *  
  2.  
  3. FROM (SELECT ROWNUM r,t1.* From 表名称 t1 where rownum < M + N) t2  
  4.  
  5. where t2.r >= M 

 

例如从表Sys_option(主键为sys_id)中从10条记录还是检索20条记录,语句如下:

 

  1. SELECT *  
  2.  
  3. FROM (SELECT ROWNUM R,t1.* From Sys_option where rownum < 30 ) t2  
  4.  
  5. Where t2.R >= 10 

 

MySQL数据库

MySQL数据库最简单,是利用mysql的LIMIT函数,LIMIT [offset,] rows从数据库表中M条记录开始检索N条记录的语句为:SELECT * FROM 表名称 LIMIT M,N。

例如从表Sys_option(主键为sys_id)中从10条记录还是检索20条记录,语句如下:select * from sys_option limit 10,20 。

关于Oracle、SQL Server、MySQL数据库分页查询的知识就介绍到这里了,希望本次的介绍能够对您有所帮助。

【编辑推荐】

  1. SQL Server链接服务器访问DB2设置步骤图解
  2. 初学SQL Server存储过程的一些简单操作示例
  3. T-SQL查询中基于列的逻辑表达式的查询详解
  4. 擦亮自己的眼睛去看SQL Server之谈谈锁机制
  5. SQL Server中通过设置SET NOCOUNT来优化存储过程
责任编辑:赵鹏 来源: CSDN博客
相关推荐

2009-05-15 10:11:55

数据库查询查询性能分页浏览

2012-07-23 14:30:33

Oracle

2011-04-06 11:16:47

SQL Server数查询优化

2009-07-28 09:51:11

Flex数据分页查询

2011-08-05 13:29:04

分页

2011-08-03 09:37:11

数据库分页

2019-07-11 08:45:00

MySQL数据库缓存

2009-07-01 10:01:33

JSP分页查询MySQL数据库

2009-04-30 09:28:05

SynonymOpenquerySQL Server

2011-04-12 10:09:33

Oracle数据库关闭

2011-04-06 11:34:52

SQL Server数查询优化

2011-08-04 13:07:59

数据库查询TOP子句

2010-10-27 17:11:35

oracle查询

2011-04-12 10:33:46

Windows CE数创建

2011-04-13 15:17:09

数据库系统设计

2010-09-06 11:40:06

SqlServer语句

2011-05-18 10:36:21

数据库数据导入

2009-05-20 10:58:15

数据库查询初始化

2009-08-25 16:01:32

C#.NET连接数据库

2011-08-09 18:15:24

Oracle 10g查找数据
点赞
收藏

51CTO技术栈公众号