Oracle大表数据排序后分页查询效率很慢

    链接地址:http://www.xx566.com/detail/111.html

    好吧,昨天在整理Oracle分页,想起来做优化时候的一个知识点,需要记录下,我不是DBA,不过我也做过一些Oracle优化的工作,当然完全是通过 书本和百度。项目开发完成,为了测试数据库的性能,在几张表里添加了百万级的测试数据,一直听说Oracle处理千万级的数据性能也是杠杠的,信心满满的 上线内测了,好吧,列表页打不开了...

    不过才200万条数据,怎么会?于是开始debug,列表搜索页是通过分页展示的,项目中使用了Hibernate,并对Hibernate进行了封装,通过原生sql查询,返回分页后的数据,Hibernate生成的分页查询语句如下:

select * from (select t1.*,rownum rn from (select column1,column2 from test order by column1,column2 desc) where rownum <= 50) where rn > 0

    很快的发现了问题所在,由于列表页要求对数据进行排序展示,查询的时候对多个字段进行了排序,进行了全表扫描,导致效率缓慢,好吧,于是在多个排序字段上建立了复合索引,这样排序的时候通过索引一定会快很多。

create index test_index on test(column1,column2 desc);

    咦?为什么还是查询那么慢,依旧是全表扫描,索引没有起作用,再来,强制使用索引。

select * from (select t1.*,rownum rn from (select /*+index(test_index) */ column1,column2 from test order by column1,column2 desc) where rownum <= 50) where rn > 0

    查询依旧慢,难道是Hibernate的问题,好吧,我把Hibernate处理的部分改成了JDBC,问题依旧存在,悲催了,于是开始翻书,百度,找到了另外的一种分页查询的方式:

select * from test t1,( select rid from ( select rownum rn,t.rid from ( select /*+index(test_index) */ rowid rid from test order by column1,column2 desc ) t where rownum <= 50 ) where rn > 0) t2 where t1.rowid = t2.rid

    好吧,问题解决了,第一次做优化,对一些Oracle的机制并不熟悉,对一些问题也没有认识,目前还不清楚问题解决的原理和深层次的知识,还需要不断的学习啊。

你可能感兴趣的:(oracle,分页,效率慢)