深入探討Oracle函數索引

http://database.51cto.com/art/200911/164250.htm Oracle還是比較常用的,於是我研究了一下Oracle函數索引,在這裏拿出來和大家分享一下,希望對大家有用。 1.Oracle函數索引的好處: Exp: function(column1) 如果表中有1000行,即便column1列上建有索引,索引在此時也不被使用,function會執行1000次。 2.建立Oracle函數索引會使插入/更新性能稍有下降,但是查詢速度有了極大的提高。另外如果更新的時候沒有涉及到建立Oracle函數索引的這個列,那就不會產生額外的開銷。 3.部分行建立索引: 1)某一列只有很少的基數,例如只有Y和N 2)通常只會查詢where column1 = ‘N’ 3)並且值爲N的行佔很小的比例 4)在此列上建立索引,由於很大的一部分索引空間是浪費的(等於Y的),不會使用到的,所以我們可以在值爲’N’的那些行上面建立索引。 5)Create index I on T(decode(column1 , ‘N’, ‘N’)) 6)利用的是B樹索引特性,如果列值爲null,在索引中就沒有相應的條目。 4.使用Oracle函數索引來保證複雜的約束:(某個條件成立時,X,Y,Z必須唯一) 1)如果項目表,項目有2種狀態,ACTIVE和INACTIVE 2)希望ACTIVE的項目必須有唯一的項目名,INACTIVE的項目沒有此要求 3)此時項目狀態這列上我們不適合建立唯一鍵 4)但是我們可以建立一個唯一索引 5)Create unique index I on T(decode(STATUS , ‘ACTIVE’ , NAME)) 6)利用的還是B樹索引特性,如果列值爲null,在索引中就沒有相應的條目。 Oracle函數索引索引的一些常見問題 1.B樹索引特性,如果列值爲null,在索引中就沒有相應的條目。 1)Create table T (x int , y int) 2)Create unique index I T(x , y) 3)Insert into T values(1 , 1) 4)Insert into T values(null , 1) 5)Insert into T values(1 , null) 6)Insert into T values(null , null) 7)此時索引中只有三行.(null , null)不在索引行中 8)Insert into T values(null , null) --成功插入 9)Insert into T values(1 , null)--報錯,違反index唯一性 10) 所以我們可以看到ORACLE中null null (null代表N/A) 11) Where x is null --這個查詢無法使用索引,因爲(null,null)不在索引中,如果ORACLE使用索引就會得到錯誤的答案 12) 同樣能夠得出結論,如果在一個允許null的列上面建立索引,x is null也不會使用索引 13) 可以使用索引的條件Create table T (x int , y int not null); 2.外鍵建立索引是需要的 3.索引跳躍式掃描 1)Create index I T(x , y) 2)Select * from T where x=5; --此時優化器可能不會使用索引 3)Select x , y from T where x=5;--可能使用索引,因爲所需要的內容都在索引中 4)索引跳躍式掃描—skip scan 5)如果y只有2個基數,Y和N ,oracle會採用index 6)Select * from T where x=5; --會經過如下處理 7)Select * from T where x=5 and y=’Y’ 8)Union all 9)Select * from T where x=5 and y=’N’; 4.如果索引建立在一個允許null的列上面, select * from T就會使用全表掃描,不使用索引,因爲null的行並不在索引行中,所以不會使用index統計數目。 5.select * from T where x=5 等價於select * from T where to_number(x)=’5’,由於存在隱式轉換,所以x上的索引不會得到使用 6.where trunc(date) = trunk(sysdate) 可以轉換成 date >=trunc(sysdate) and date
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章