Oracle Hint 用法


正確的語法是:

select /*+ index(x idx_t) */ * from t x where x.object_id=123

/*+    */ 和注釋很像,比注釋多了一個“+”,這就是Hint

上面這個hint的意思是讓Oracle執行這個SQL時強制走索引。

 

如果hint的語法有錯誤,Oracle是不會報錯,只是把/* */里的內容當做注釋而已。

 

不合理使用Hint的危害:

由於表中的數據是會變化,一般不能在程序中的sql里用Hint,假如像上面的Hint一樣強制走索引。萬一某一天object_id=123的返回結果占了全表的50%以上,這時候走索引會比全表掃描慢。所以不該強制所有情況都走索引。Hint一般用於一次執行,比如做數據抽取。而且一般Oracle在99%的情況下會判斷正確是否該走索引,不需要我們去指定。Hint只是為了應付1%的情況下。

 

Append的使用:

 

append是另一種Hint,一般用法:

 

insert /*+ append */ into b select * from a;

 

這種insert比普通的insert會快一些,但代價也大。

1、當表中的數據被delete以后,表空間會留下空隙,下次insert時會去填補空隙。但是append的insert不會去找空隙,而且直接追加到新的空間里。如果一直用append,會使表空間越來越大。

2、這點是比較致命的,就是用append的時候,會把整個表鎖住,別的用戶即使insert別的數據也要被阻塞。

所以生產環境肯定不能用append,append也一般用於數據抽取一類的工作。

 

其實大多數情況下,用append提高不了多少效率。

因為append之所以快的原因,是因為減少了日志產生。

 

只有以下場景append會減少日志產生:

1、非歸檔模式下

2、歸檔模式下,表的狀態是nologging

 

首先非歸檔狀態一般是不可能的,稍微重要點的系統都必須開歸檔。

歸檔模式下nologging一般也很少,沒日志了,也就意味着將來恢復數據會不完整,這是有風險的。

 

總之就是,Hint適用的場景其實很少,就是知道有這么個東西,用的時候要謹慎。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM