分页技术:Oracle \rownum\新发现

王朝oracle·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

笔者在工作中有一上百万条记录的表,在jsp页面中需对该表进行分页显示, 便考虑用rownum来作,下面是具体方法(每页

显示20条):

“select * from tabname where rownum<20 order by name" 但却发现Oracle却不能按自己的意愿来执行,而是先随便

取20条记录,然后再 order by,后经咨询oracle,说rownum确实就这样,想用的话,只能用子查询 来实现先排序,后

rownum,方法如下:

"select * from (select * from tabname order by name) where rownum<20",但这样一来,效率会较低很多。

后经笔者试验,只需在order by 的字段上加主键或索引即可让oracle先按 该字段排序,然后再rownum;方法不变:

“select * from tabname where rownum<20 order by name"

经笔者反复验证,都没有问题。 笔者偶然中发现这一秘诀,不敢独珍,写出来特与网友分享!!!如有谬误之处 , 欢迎

大家批评指正! 本人系统环境solaris,oracle815,不知其它版本的Oracle 怎么样,如有朋友 发现与我的试验结果不同,

欢迎与我交流!

本人mail: caohw@legend.com.cn

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航