服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Oracle - 简单实例解释Oracle分页查询

简单实例解释Oracle分页查询

2020-04-17 15:27梦回流年梦呓语 Oracle

这篇文章主要给大家介绍了关于Oracle分页查询的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Oracle具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧

什么是分页查询

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

为什么要分页查询

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

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

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

如何实现分页查询

使用Oracle的EMP表

?
1
2
3
4
select * from
   ( select rownum rn, e.* from
       ( select * from EMP) e
   );

结果如下:

简单实例解释Oracle分页查询

分页查询源码如下:

?
1
2
3
4
5
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。

?
1
where rn > 5 and rn <= 10

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

?
1
2
3
4
5
select * from
     ( select rownum rn, e.* from
              ( select * from EMP) e
     )
where rn > 5 and rn <= 10

结果如下:

简单实例解释Oracle分页查询

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

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

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

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对服务器之家的支持。

原文链接:https://segmentfault.com/a/1190000021026631

延伸 · 阅读

精彩推荐