正確的語法是:
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適用的場景其實很少,就是知道有這么個東西,用的時候要謹慎。