Oracle Hint 用法

來源:互聯網
上載者:User

標籤:style   使用   資料   re   c   工作   sql   size   

正確的文法是:

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適用的情境其實很少,就是知道有這麼個東西,用的時候要謹慎。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.