时间:2021-07-01 10:21:17 帮助过:281人阅读
----------------------------------------------------------------
涉及到大数据量的查询时我们一般不会想要全部查看,而只是想要汇总、根据条件筛选、查询前面几页数据等。鉴于此用上面的解决方案却不能查询从21到40之间的数据,特修改语句如下:
select * from ( select s.*,rownum rowN from tabname s order by stuno desc ) m where m.rowN between 200 and 300
使用之后才发现效率还是比较慢,因为嵌套查询内部每次都要检索tabname的所有数据,故在此修改如下:
select * from ( select s.*,rownum rowN from tabname s where rownum<300 order by stuno desc ) m where m.rowN between 200 and 300
因为查询的是前200到300之间的数据,所以没有比较检索表中所有数据,故在嵌套查询内部加了个rownum<300进行筛选。当我们越是往后面分页,那么嵌套查询内部数据越大,效率就越低,但是如果只考虑查询前面几页数据,无疑是最好的方式。
Oracle 千万级别数据查询优化
标签: