容易引發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 只要在創建的索引列(不分前後)都會走。