1. 程式人生 > 資料庫 >Oracle使用強制索引的方法與注意事項

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 hh24:mi:ss' 
 ) 
AND date < TO_DATE ( 
 '2016-11-30','yyyy-mm-dd hh24:mi:ss' 
); 

2、T_MAINS已根據某個時間型別的欄位進行分割槽,查詢條件中如果能夠精準定位到某個分割槽,可以提高SQL的執行效率

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對我們的支援。