索引失效原因总结

如果是同样的sql如果在之前能够使用到索引,纳闷现在使用不到索引,以下几种主要情况:

  1. 随着表的增长,where条件出来的数据太多,大于15%,使得索引(会导致CBO计算走索引花费大于走全表)
  2. 统计信息失效    需要重新搜索统计信息。
  3. 索引本身失效    需要重建索引

下面是一些不会使用到索引的原因。

索引失效

         正确的例子:select * from test where tu_mdn = '12312312'

  1. 没有查询条件,或者查询条件没有建立索引
  2. 在查询条件上没有使用引导列
  3. 查询的数量是大表的大部分,应该是30%
  4. 索引本身失效
  5. 查询条件使用函数在索引列上
  6. 对小表查询
  7. 提示不使用索引
  8. 统计数据不真实
  9. CBO计算走索引花费过大的情况,其实也包含了上面的情况,这里指的是表占有的block要比索引小。
  10. 隐式转换导致索引失效,这一点应当引起重视,也是开发中经常会犯的错误,由于表的字段tu_mdn定义为varchar(20)。但在查询时把该字段作为number类型以where条件传给Oracle,这样会导致索引失效。                        错误的例子:select * from test where tu_mdn = 11231231                                                                           
  11. 对索引进行运算导致索引失效,我所指的对索引列进行运算包括(+,-,*,/,!等)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值