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

33次阅读

共计 700 个字符,预计需要花费 2 分钟才能阅读完成。

什么是分页查询

分页查询就是把 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

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

正文完
 0