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

好吧,昨天在整理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的机制并不熟悉,对一些问题也没有认识,目前还不清楚问题解决的原理和深层次的知识,还需要不断的学习啊。

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值