这篇文章给大家分享的是有关Oracle如何实现分页查询的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

什么是分页查询

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

为什么要分页查询

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

我们可以为了以下目的使用分页查询:

为了精确定位结果集的内容

为了节约内存

为了在有限的页面空间显示适度的数据。

如何实现分页查询

使用Oracle的EMP表

select*from(selectrownumrn,e.*from(select*fromEMP)e);

结果如下:

分页查询源码如下:

select*from(selectrownumrn,e.*from(select*fromEMP)e)wherern>pageSize*(page-1)andrn<=pageSize*page

分析源码:

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

页面从第1页开始。

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

wherern>5andrn<=10

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

select*from(selectrownumrn,e.*from(select*fromEMP)e)wherern>5andrn<=10

结果如下:

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

wherern=between(pageSize*(page-1)+1)andpageSize*page

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

感谢各位的阅读!关于“Oracle如何实现分页查询”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!