分页技术

分页技术,第1张

概述--------------------Oracle分页技术------------------------------ Oracle数据库为我们提供了两个很重要的字段:RowId和RowNumber。RowId是一个绝对的值,是针对某一行分配的一个唯一的行标识符,根据它我们可以非常迅捷地定位到某一个具体的行。它也起着主键的作用,即它是唯一的(Unique)、必有的(Mandatory)字段。Ro

--------------------Oracle分页技术------------------------------
Oracle数据库为我们提供了两个很重要的字段:RowID和RowNumber。RowID是一个绝对的值,是针对某一行分配的一个唯一的行标识符,根据它我们可以非常迅捷地定位到某一个具体的行。它也起着主键的作用,即它是唯一的(Unique)、必有的(Mandatory)字段。RowNumber是一个相对的值,是指查询结果的行号。例如Standard标准题录表中有三条题录信息,那么每行对应的RowNumber即为1、2、3。它是一个从1开始标记的行数信息。根据RowNumber,我们就可以实现分页技术了。

select * from thetable
where rownumber between ((页码-1) * 页容量 + 1) and (页码 * 页容量)
select * from thetable
where rowID not in(
  select rowID from thetable where rownum<=(页码-1)*页容量
) and rownum<=页码*页容量
select top 页容量 * from thetable where ID>(
  select max (ID) from(
    select top ((页码-1)*页容量) ID from table1 order by ID
  )
)
order by ID

select * from thetable limit (页码-1)*页容量,页码*页容量

例如如果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 rownum<=*页容量



-------------------------sqlServer分页技术-------------------------------


sqlServer的分页方法和Oracle不尽相同。sqlServer并没有提供Oracle特有的RowID和Rownumber两个字段,而是使用了top这个关键字:

select top 10 * from thetable或是select top (10) * from thetable。

sqlServer2000使用前者不加括号的书写方法,sqlServer2005开始支持括号,增加可读性。通过top关键字,可以限制查询只取得结果集的前多少行。



-----------------------MysqL分页技术-----------------------------------------

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

总结

以上是内存溢出为你收集整理的分页技术全部内容,希望文章能够帮你解决分页技术所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1177693.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存