您好,登錄后才能下訂單哦!
小編給大家分享一下Oracle如何使用強制索引,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
Oracle使用強制索引
在一些場景下,可能ORACLE不會自動走索引,這時候,如果對業務清晰,可以嘗試使用強制索引,測試查詢語句的性能。
以EMP表為例:
先在EMP表中建立唯一索引,如圖。
普通搜索:
SELECT * FROM EMP T
查看執行計劃:
可以看到,是走的全表掃描。
使用強制索引,在SELECT 后面加上/*.......*/ 中間加上索引的屬性,代碼如下:
SELECT /*+index(t pk_emp)*/* FROM EMP T --強制索引,/*.....*/第一個星星后不能有空格,里邊內容結構為:加號index(表名 空格 索引名)。 --如果表用了別名,注釋里的表也要使用別名。
可以看到,這是走的是索引PK_EMP。
Oracle使用強制索引注意事項
最近對Oracle的SQL索引生效條件進行了驗證,發現如下規律,記錄如下:
1、索引生效與記錄的條數相關
a、2016-01-01~2016-11-30 數據量402518,索引生效
b、2016-01-01~2016-12-30 數據量444844,索引不生效
SELECT * FROM T_MAINS WHERE date > TO_DATE (--備注今天是2017-01-23 '2016-01-01', 'yyyy-mm-dd hh34:mi:ss' ) AND date < TO_DATE ( '2016-11-30', 'yyyy-mm-dd hh34:mi:ss' );
2、T_MAINS已根據某個時間類型的字段進行分區,查詢條件中如果能夠精準定位到某個分區,可以提高SQL的執行效率
以上是“Oracle如何使用強制索引”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。