ORACLE 查询不走索引的原因分析,解决办法通过强制索引或动态执行SQL语句提高查询速度...

本文分析了Oracle查询中索引不被利用的原因,如时间范围查询、LIKE操作、未定期分析统计信息等,并提供了相应解决办法,如强制使用索引、调整SQL语句。同时讨论了通过动态执行SQL提升COUNT()查询速度的方法。
摘要由CSDN通过智能技术生成

(一)索引失效的原因分析:

  • <>或者单独的>,<,(有时会用到,有时不会)
  • 有时间范围查询;oracle 时间条件值范围越大就不走索引
  • like "%_" 百分号在前.
  • 表没分析(统计信息最好定期收集,以业务的不同确定不同的收集周期,在新增的索引有可能没有收集 ,那么就会导致索引失效)

  解决方法:

    分析方法有一下几种:
    analyze table t1 compute statistics fortable; --针对表收集信息

    analyze table t2 compute statistics for allcolumns; --针对表字段收集信息

    analyze table t3 compute statistics for all indexescolumns; --收集索引字段信息

    analyze table t4 computestatistics;       --收集表,表字段,索引信息

    analyze table t5 compute statistics for allindexes;         --收集索引信息

    analyze table t6 compute statistics for table for all indexesfor allcolumns;   --

    --收集表,索引,表字段信息

  • 单独引用复合索引里非第一位置的索引列.
  • 字符型字段为数字时在where条件里不添加引号.
  • 对索引列进行运算.需要建立函数索引.
  • not in ,not exist.
  • 当变量采用的是times变量,而表的字段采用的是date变量时.或相反情况。
  • 索引失效。
  • 基于cost成本分析(Oracle因为走全表成本会更小):查询小表,或者返回值大概在10%以上;

  解决办法:

    在这种条件下 oracle会认为索引更占资源,就默认不走索引了。这种情况如果觉得索引快的,通过强制索引提高查询速度 

     select   /*+INDEX(t IDEX_HZYB_JSJL_BDJSRQ)*/   from hzyb_jsjl t
     where BDJSRQ >TO_DATE('','');

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值