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