首页数据库简单实例解释Oracle分页查询

简单实例解释Oracle分页查询

时间2024-02-28 16:42:03发布访客分类数据库浏览679
导读:收集整理的这篇文章主要介绍了简单实例解释Oracle分页查询,觉得挺不错的,现在分享给大家,也给大家做个参考。 什么是分页查询分页查询就是把query到的结果集按页显示。比如一个结果集有...
收集整理的这篇文章主要介绍了简单实例解释Oracle分页查询,觉得挺不错的,现在分享给大家,也给大家做个参考。

什么是分页查询

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

为什么要分页查询

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

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

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

如何实现分页查询

使用oracle的EMP表

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

结果如下:

分页查询源码如下:

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

结果如下:

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

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

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

总结

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

@H_360_93@您可能感兴趣的文章:
  • oracle,mysql,SqlServer三种数据库的分页查询的实例
  • Oracle实现分页查询的SQL语法汇总
  • Oracle、MySQL和SqlServe三种数据库分页查询语句的区别介绍
  • Oracle分页查询性能优化代码详解
  • Oracle分页查询的实例详解
  • mysql、mssql及oracle分页查询方法详解
  • 详解SQLServer和Oracle的分页查询
  • 详解oracle分页查询的基础原理
  • oracle实现一对多数据分页查询筛选示例代码
  • Oracle使用MyBatis中RowBounds实现分页查询功能

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: 简单实例解释Oracle分页查询
本文地址: https://pptw.com/jishu/631679.html
PL/SQL登录Oracle数据库报错ORA-12154:TNS:无法解析指定的连接标识符已解决(本地未安装Oracle需要连接服务器上的) Centos7下oracle12c的安装与配置图文教程(详细)

游客 回复需填写必要信息