当前位置:Gxlcms > 数据库问题 > Oracle 千万级别数据查询优化

Oracle 千万级别数据查询优化

时间:2021-07-01 10:21:17 帮助过:281人阅读

,然后再rownum;方法不变:
"select * from tabname where rownum<20 order by name"

----------------------------------------------------------------

涉及到大数据量的查询时我们一般不会想要全部查看,而只是想要汇总、根据条件筛选、查询前面几页数据等。鉴于此用上面的解决方案却不能查询从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 千万级别数据查询优化

标签:

人气教程排行