您的位置:首页 > 数据库 > Oracle

oracle使用rownum跟排序的冲突问题解决

2011-09-29 10:02 417 查看
 “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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  oracle 咨询