简单实例解释Oracle分页查询
什么是分页查询
分页查询就是把query到的结果集按页显示。比如一个结果集有1W行,每页按100条数据库。而你获取了第2页的结果集。
为什么要分页查询
如果一个结果集有几十W行,那么在一个页面上显示肯定显示不完。同时,显示数据库记录是需要加载到内存的,而显示大量数据是消耗内存更多。
我们可以为了以下目的使用分页查询:
- 为了精确定位结果集的内容
- 为了节约内存
- 为了在有限的页面空间显示适度的数据。
如何实现分页查询
使用Oracle的EMP表
select*from (selectrownumrn,e.*from (select*fromEMP)e );
结果如下:
分页查询源码如下:
select*from (selectrownumrn,e.*from (select*fromEMP)e ) wherern>pageSize*(page-1)andrn<=pageSize*page
分析源码:
我们选定每页(pageSize)为5。那么EMP表目前共有三页,1~5行为1页;6~10行为1页;1~15行为1页(缺第15行,那么第3页就显示4行记录)
页面从第1页开始。
我们要查询第2页的记录,那么page=2。
wherern>5andrn<=10
那么第2页是由第6,7,8,9,10行记录形成的。
select*from (selectrownumrn,e.*from (select*fromEMP)e ) wherern>5andrn<=10
结果如下:
分页查询也可以使用betwenn...and...
wherern=between(pageSize*(page-1)+1)andpageSize*page
可见分页查询是取某一范围的结果集。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对毛票票的支持。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。