分页查询就是把query
到的结果集按页显示。好比一个结果集有1W行,每页按100条数据库。而你获取了第2页的结果集。sql
若是一个结果集有几十W行,那么在一个页面上显示确定显示不完。同时,显示数据库记录是须要加载到内存的,而显示大量数据是消耗内存更多。数据库
咱们能够为了如下目的使用分页查询:spa
使用Oracle的EMP表code
select * from ( select rownum rn, e.* from ( select * from EMP) e );
结果以下:blog
分页查询源码以下:内存
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
结果以下:
分页查询也能够使用betwenn ... and ...
where rn = between (pageSize * (page - 1) + 1) and pageSize * page
可见分页查询是取某一范围的结果集。