oracle在列表排序的时候,由于一个Order by 的字段是desc的时候,查询20条记录要一秒多,而如果排序是asc则只需要0.0几毫秒,这个差距有点大
看了一下分析,主要区别就在于有没有:ORDER BY STOPKEY这个。
关于ORDER BY STOPKEY的可以搜索查询相关资料,这里就不再解释,这里主要说一下我的思路
原来order by a字段的时候,前面有条件,分别为b和c,在b,c,a上建立了符合索引,这里走了弯路,索引的排序与是否使用索引关系不大,之前一直纠结是否索引排序的问题。
解决方案是:把order by后的a字段加入到where条件中,并在order by 后面增加字段b 的降序排序。
------------正 文 已 结 束, 感 谢 您 的 阅 读 (折雨的天空)--------------------
转载请注明本文标题和链接:《ORDER BY STOPKEY rownum 优化》
发表评论