首頁  >  文章  >  資料庫  >  詳解Oracle使用強制索引的方法與注意事項

詳解Oracle使用強制索引的方法與注意事項

小云云
小云云原創
2017-12-11 14:34:461949瀏覽

本文主要為大家介紹了關於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 ( 
 &#39;2016-11-30&#39;, 
 &#39;yyyy-mm-dd hh24:mi:ss&#39; 
);

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

相關推薦:

mysql與oracle資料庫停止與啟動的批次檔

#如何向MySQL資料庫或Oracle或匯入表格檔案

############################################################# ####oracle 用HINT方式強制索引######

以上是詳解Oracle使用強制索引的方法與注意事項的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn