用简单的例子解释Oracle分页查询

什么是分页查询

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

为何要分页查询

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

咱们能够为了如下目的使用分页查询:spa

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

如何实现分页查询

使用Oracle的EMP表code

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

结果以下:blog

image-20191115204015710.png

分页查询源码以下:内存

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行记录)it

页面从第1页开始。class

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

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

结果以下:
image-20191115204450422.png

分页查询也能够使用betwenn ... and ...

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

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

相关文章
相关标签/搜索