oracle 索引使用及索引失效總結
容易引起oracle索引失效的原因很多:
1、在索引列上使用函式。如SUBSTR,DECODE,INSTR等,對索引列進行運算.需要建立函式索引就可以解決了。
2、新建的表還沒來得及生成統計資訊,分析一下就好了
3、基於cost的成本分析,訪問的表過小,使用全表掃描的消耗小於使用索引。
4、使用<>、not in 、not exist,對於這三種情況大多數情況下認為結果集很大,一般大於5%-15%就不走索引而走FTS。
5、單獨的>、<。
6、like "%_" 百分號在前。
7、單獨引用複合索引裡非第一位置的索引列。
8、字元型欄位為數字時在where條件裡不新增引號。
9、當變數採用的是times變數,而表的欄位採用的是date變數時.或相反情況。
10、索引失效,可以考慮重建索引,rebuild online。
11、B-tree索引 is null不會走,is not null會走,點陣圖索引 is null,is not null 都會走、聯合索引 is not null 只要在建立的索引列(不分先後)都會走。來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/30557618/viewspace-1833478/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Oracle資料庫索引使用及索引失效總結 轉Oracle資料庫索引
- 建立索引後,速度變快原因?以及索引失效總結索引
- MySQL系列:索引失效場景總結MySql索引
- Oracle索引失效-likeOracle索引
- oracle 索引分析及索引重建Oracle索引
- 索引總結索引
- mysql索引使用經驗總結MySql索引
- C# 索引器使用總結C#索引
- Oracle drop,truncate partition 索引失效 實驗Oracle索引
- mysql索引總結MySql索引
- MySQL 索引及查詢優化總結MySql索引優化
- 索引失效場景索引
- 單個分割槽索引失效導致繫結變數查詢無法使用索引索引變數
- 【實驗】【索引壓縮】索引壓縮演示及優缺點總結索引
- Oracle表與索引的分析及索引重建Oracle索引
- 【索引】oracle查詢使用索引和不使用索引的比較索引Oracle
- MySQL索引——總結篇MySql索引
- [資料庫]索引失效資料庫索引
- MySql ORDER BY索引是否失效MySql索引
- Oracle表與索引的分析及索引重建(轉)Oracle索引
- MYSQL索引失效的各種情況小結MySql索引
- ORACLE 索引使用規Oracle索引
- 關於 Oracle 分割槽索引的失效和重建Oracle索引
- Oracle中B-Tree、Bitmap和函式索引使用案例總結Oracle函式索引
- mysql關於聚集索引、非聚集索引的總結MySql索引
- oracle 定期表及索引分析Oracle索引
- mysql索引失效的情況MySql索引
- 索引失效系列——說說is null索引Null
- 探索MySQL的InnoDB索引失效MySql索引
- Oracle分割槽之五:建立分割槽索引總結Oracle索引
- 索引失效系列——繫結變數引起的peeking索引變數
- Oracle隱式型別轉換導致索引失效Oracle型別索引
- [zt] 聚集索引和非聚集索引(sql server索引結構及其使用)索引SQLServer
- 分割槽表 全域性索引與本地索引失效測試索引
- Oracle索引HINT的使用Oracle索引
- oracle index索引結構(一)OracleIndex索引
- 索引@oracle索引技術索引Oracle
- MySQL的索引原理及使用MySql索引