使用ORACLE索引的一些小技巧

來源:互聯網
上載者:User
 

索引對資料庫訪問的效能的作用十分巨大,設計合理的索引對於系統效能調整至關重要。而使用索引又是資料庫開發過程   中最困難的一點。在設計索引的時候要注意以下幾個方面:

 

l         在OLTP系統中,盡量避免全表掃描,盡量使絕大多數操作都通過索引訪問

l         資料量很大並且經常變動的表上的索引不易過多,過量的索引會導致插入、更新和刪除操作變慢,產生大量的IO,如果一張表上的索引超過8個,就需要檢查是否這些索引都是必要的。(但是要值得注意的是這條原則很可能被過度的誇大。因為絕大多數OLTP系統,寫操作不足10%,絕大多數的操作是讀。因此如果是設計的合理,並不能說一張表上的索引超過多少就是不合理的)

l         如果索引數量過多,建議刪除部分所有的列都建有獨立索引的複合索引,複合查詢操作可以通過使用兩個獨立列的索引結果集合并來擷取,也可以保障查詢效率

l         小表不要建立索引,可能通過索引訪問速度更慢,把小表放入KEEP 池效率更高

l         索引的PCTFREE、INITTRANS、MAXTRANS參數設定十分重要,特別是對於變化十分大的索引

l         對於比較大的索引,使用索引分割區會改善效率

l         位元影像索引對於列表類值的效果較好(索引大小也比較小),但是位元影像索引不適合變化十分頻繁的表

l         使用函數索引可以避免大量不必要的全表掃描

l         如果索引包含了查詢需要的所有資訊,查詢就不需要訪問表的資料,可以大大提高訪問效率,因此要注意建立合理的複合索引,並注意SQL語句的合理性

l         用好索引組織表

l         可以使用反轉索索引值索引來消除索引相關的熱塊

l         隨著資料的變化,索引的效率會下降,因此定期重建索引對於效能提升有很大協助

l         使用CBO最佳化器的情況下,保證表和索引的資料得到了良好的分析是保證最佳化器選擇最佳執行計畫的關鍵

l         刪除所有不必要的索引。ORACLE 9i提供的新特性可以使DBA能夠跟蹤索引的使用方式,用這個功能找到不使用的索引,並把這些索引刪除

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.