程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle教程 >> oracle性能優化操作八:利用HINT強制指定索引

oracle性能優化操作八:利用HINT強制指定索引

編輯:Oracle教程

oracle性能優化操作八:利用HINT強制指定索引


在ORACLE優化器無法用上合理索引的情況下,利用HINT強制指定索引。

繼續“oracle 性能優化操作七”的例子,ORACLE缺省認定,表中列的值是在所有數據行中均勻分布的,

也就是說,在一百萬數據量下,每種DisposalCourseFlag值各有12.5萬數據行與之對應。

假設SQL搜索條件DisposalCourseFlag=2,利用DisposalCourseFlag列上的索引進行數據搜索效率,

往往不比全表掃描的高,ORACLE因此對索引“視而不見”,從而在查詢路徑的選擇中,用其他字段上的索引甚至全表掃描。

根據我們上面的分析,數據值的分布很特殊,嚴重的不均勻。為了利用索引提高效率,此時,

一方面可以單獨對該字段或該表用analyze語句進行分析,對該列搜集足夠的統計數據,使ORACLE在查詢選擇性較高的值時能用上索引;

另一方面,可以利用HINT提示,在SELECT關鍵字後面,加上“/*+ INDEX(表名稱,索引名稱)*/”的方式,強制ORACLE優化器用上該索引。

比如:

select * from  serviceinfo where DisposalCourseFlag=1 ; 

上面的語句,實際執行中ORACLE用了全表掃描,HINT部分後,用到索引查詢。如下:

select /*+  INDEX(SERVICEINFO,IX_S_DISPOSALCOURSEFLAG)  */  *  from  serviceinfo where DisposalCourseFlag=1;

請注意,這種方法會加大代碼維護的難度,而且該字段上索引的名稱被改變之後,必須要同步所有指定索引的HINT代碼,

否則HINT提示將被ORACLE忽略掉。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved