详解Oracle分页查询概念、缘由及如何实现

详解Oracle分页查询概念、缘由及如何实现( select rownum rn, e.* fromwhere rn > pageSize * and rn <= p

大家好,欢迎来到IT知识分享网。

概述

很多朋友都不太理解为什么要去分页查询,今天主要用一个简单实例来解释下Oracle数据库的分页查询。。。


分页查询概念

分页查询就是把query到的结果集按页显示。比如一个结果集有1W行,每页按100条数据,而你获取了第2页的结果集。


为什么要分页查询

如果一个结果集有几十W行,那么在一个页面上显示肯定显示不完。同时,显示数据库记录是需要加载到内存的,而显示大量数据是消耗内存更多。

总之,我们是为了以下目的使用分页查询:

  • 为了精确定位结果集的内容
  • 为了节约内存
  • 为了在有限的页面空间显示适度的数据

分页查询实现

使用Oracle的EMP表,原始sql如下:

select * from ( select rownum rn, e.* from ( select * from EMP) e);

结果如下:

详解Oracle分页查询概念、缘由及如何实现

分页查询sql如下:

select * from ( select rownum rn, e.* from ( select * from EMP) e ) where rn > pageSize * (page - 1) and rn <= pageSize * page

说明:

假设选定每页(pageSize)为5。那么EMP表目前共有三页,1~5行为1页;6~10行为1页;1~15行为1页(缺第15行,那么第3页就显示4行记录),页面从第1页开始。

我们要查询第2页的记录,那么page = 2。

where rn > 5 and rn <= 10

那么第2页是由第6,7,8,9,10行记录形成的。

select * from ( select rownum rn, e.* from ( select * from EMP) e ) where rn > 5 and rn <= 10

结果如下:

详解Oracle分页查询概念、缘由及如何实现

分页查询也可以使用betwenn … and …

where rn = between (pageSize * (page - 1) + 1) and pageSize * page

可见分页查询是取某一范围的结果集。


讲的有点简单…大家有空也可以自己测试一下~觉得有用的朋友多帮忙转发哦!后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注下~

详解Oracle分页查询概念、缘由及如何实现

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/60339.html

(0)
上一篇 2024-06-13 18:33
下一篇 2024-06-26 11:33

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信