不同数据库的分页技术

原创 2013年12月03日 22:59:40

针对不同的数据库,分页的实现方法是不一样的。
Oracle分页技术
Oracle数据库为我们提供了两个很重要的字段:RowId和RowNumber。RowId是一个绝对的值,是针对某一行分配的一个唯一的行标识符,根据它我们可以非常迅捷地定位到某一个具体的行。它也起着主键的作用,即它是唯一的(Unique)、必有的(Mandatory)字段。RowNumber是一个相对的值,是指查询结果的行号。例如Standard标准题录表中有三条题录信息,那么每行对应的RowNumber即为1、2、3。它是一个从1开始标记的行数信息。根据RowNumber,我们就可以实现分页技术了。
但是在实施的过程中,也遇到了一个问题。最开始我认为这样写就可以了:
select * from thetable
where rownumber between ((页码-1) * 页容量 + 1) and (页码 * 页容量)
例如如果10条一页,取第二页的内容,那么就是:select * from thetable where rownumber between (2-1)*10+1 and 2*10。但这是错误的,返回结果会是一个空集合。对rownumber实施where条件查询是有限制的,只能求前多少多少行,即where rownumber<somevalue。所以只能让rownumber小于某一值,不能求中间的某一个值域。
虽然RowNumber不能按照上述的方法使用,但是依然存在别的方法来分页。如果我们求100-200行的记录,需要使用两层select语句。内层只需要先select出前100行的rowid,以便于从前200行中排除;外层select要做两件事情,一是求出前200行数据,二是排除前100行数据。这样,分页技术便实现了。
经过改造,在Oracle下分页的sql语句如下:
select * from thetable
where rowid not in(
select rowid from thetable where rownum<=(页码-1)*页容量
) and rowid in(select rowid from thetable where rownum<=页码*页容量)


SqlServer分页技术
SQLServer的分页方法和Oracle不尽相同。SQLServer并没有提供Oracle特有的RowId和Rownumber两个字段,而是使用了top这个关键字:select top 10 * from thetable或是select top (10) * from thetable。SQLServer2000使用前者不加括号的书写方法,SQLServer2005开始支持括号,增加可读性。通过top关键字,可以限制查询只取得结果集的前多少行。这个等价于Oracle的where rownumber<somevalue,也同样可以实现分页技术。所以在SQLServer下的分页sql语句写法如下:
select top 页容量 * from thetable where id>(
select max (id) from(
    select top ((页码-1)*页容量) id from table1 order by id
)
)
order by id


MySql分页技术
MySql数据库的分页技术实现起来要比前两种数据库简单一些。由于加入了关键字limit,分页在MySql下面显得非常简单。语句如下:
select * from thetable limit (页码-1)*页容量 , 页码*页容量
limit关键字是个index,即起始值从0开始。

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

分页查询是数据库查询中经常用到的一项操作,对查询出来的结果进行分页查询可以方便浏览。那么Oracle、SQL Server、MySQL是如何实现查询的呢?本文我们就来介绍这一部分内容。 首先我们...
  • yztezhl
  • yztezhl
  • 2014年03月04日 22:23
  • 3427

(四)struts2- 2.3.15.3 spring3.2.4 mybatis-3.2.3 通用分页(不同数据库) 拦截器

mybatis没有根据数据库方言进行分页封装,但是提供了拦截器,我们可以在拦截其中获取数据库方言(数据库方言通过配置文件获取)和查询sql,根据数据库方言进行翻页分装,在拦截其中有两种实现方式: ...
  • chinarenzhou
  • chinarenzhou
  • 2014年01月27日 17:16
  • 6414

oracle,mysql,SqlServer三种数据库的分页查询的实例

oracle,mysql,SqlServer三种数据库的分页查询的实例,需要的朋友可以参考一下 MySql: MySQL数据库实现分页比较简单,提供了 LIMIT函数。一般只需要直接写到sql语句...
  • qq_37878579
  • qq_37878579
  • 2018年01月01日 23:46
  • 45

oracle,mysql,SqlServer三种数据库的分页查询总结

MySql: MySQL数据库实现分页比较简单,提供了 LIMIT函数。一般只需要直接写到sql语句后面就行了。 LIMIT子 句可以用来限制由SELECT语句返回过来的数据数量,它有一个或两个参...
  • SH_King
  • SH_King
  • 2015年07月31日 15:36
  • 1821

不同数据库的分页技术

引言:数据库的分页技术,也不是处理大数据的万能药,特别是涉及到动态数据大数据时,每次都需要重新计算总记录数,绝对是数据库的性能下降,建议针对动态数据或是大数据的数据库表,采用数据库读写分离+ 缓存的模...
  • u014467099
  • u014467099
  • 2015年04月25日 18:51
  • 162

不同数据库中的分页查询方法

在实际应用中,往往能碰到分页的需求。虽然有不少组件可以实现面向对象的分页,但是都是利用了缓存。很多时候,这些方法是不可用的。原因很简单,在一个数据量非常大的应用中,缓存全部数据无论是对网络传输还是对内...
  • lihb018
  • lihb018
  • 2014年04月15日 10:10
  • 479

分页显示数据库数据

数据分页显示作为网站显示数据的必备需求之一,每个程序猿都应该懂得如何将获取到的数据进行分页后展示。我今天要分享的不是简单的分页显示数据,而是将获取到的数据转换成JSON格式。如果想要的数据复杂的话,就...
  • yanglun1
  • yanglun1
  • 2015年07月30日 16:59
  • 962

数据库 分页优化的四种方式

很久以前读了一篇关于分页的文章,后来越想越有道理,最近又重新找出来,并做了翻译,原文参考:Four ways to optimize paginated displays.翻译背景:在大数据量的情况下...
  • qilixiang012
  • qilixiang012
  • 2015年06月04日 20:51
  • 1524

数据分页实现简介

数据分页在动态网站设计里是一门必须要掌握的技能,我们要将数据库里大量的数据有条理的显示在页面上,就必须要使用到数据分页,让显示到界面的数据是最有价值的数据。那么我通过下面的例子简单的介绍一下。    ...
  • why15732625998
  • why15732625998
  • 2016年06月10日 08:32
  • 1933

ASP.NET下数据展示与分页操作总结

ASP.NET作为.NET下开发网站的首选,与数据库打交道是必然的。特别在相关的数据展示与操作这一块,其性能和用户体验对一个网站尤其重要。一个有着对用户操作进行快速响应的网站无疑在当前已经成为一种最基...
  • gxwzmm
  • gxwzmm
  • 2014年01月02日 15:22
  • 2113
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:不同数据库的分页技术
举报原因:
原因补充:

(最多只允许输入30个字)