Oracle數據庫索引使用及索引失效總結

  容易引發oracle索引失效的緣由不少:oracle

  一、在索引列上使用函數。如SUBSTR,DECODE,INSTR等,對索引列進行運算.須要創建函數索引就能夠解決了。函數

  二、新建的表還沒來得及生成統計信息,分析一下就行了ui

  三、基於cost的成本分析,訪問的表太小,使用全表掃描的消耗小於使用索引。spa

  四、使用<>、not in 、not exist,對於這三種狀況大多數狀況下認爲結果集很大,通常大於5%-15%就不走索引而走FTS。索引

  五、單獨的>、<。變量

  六、like "%_" 百分號在前。date

  七、單獨引用複合索引裏非第一位置的索引列。引用

  八、字符型字段爲數字時在where條件裏不添加引號。im

  九、當變量採用的是times變量,而表的字段採用的是date變量時.或相反狀況。統計

  十、索引失效,能夠考慮重建索引,rebuild online。

  十一、B-tree索引 is null不會走,is not null會走,位圖索引 is null,is not null  都會走、聯合索引 is not null 只要在創建的索引列(不分前後)都會走。