“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 (select * from tabname order by name) where rownum<20",但这样一来,效率会低很多。
后经笔者试验,只需在order by 的字段上加主键或索引即可让oracle先按该字段排序,然后再rownum
本文探讨了在Oracle中使用ROWNUM进行数据筛选时遇到的问题,通过在排序字段上添加主键或索引,可以优化查询性能,避免效率损失。介绍了使用子查询作为替代方案的方法,以及为何这种方法可能导致性能下降。
2228

被折叠的 条评论
为什么被折叠?



