Oracle的自定義函數,提供了對邏輯的封裝能力,便于我們對代碼進行管理。然而當這個函數出現在where語句中,它卻很可能給我們的SQL語句帶來嚴重的效率問題。因為:
成都創新互聯公司專業提供成都主機托管四川主機托管成都服務器托管四川服務器托管,支持按月付款!我們的承諾:貴族品質、平民價格,機房位于中國電信/網通/移動機房,川西大數據中心服務有保障!
1、Oracle的優化器無法對函數進行優化,只能逐行執行(這就是為什么我們常發現,把函數里面的語句拷出來,就會執行得很快的原因)
2、函數并非標準SQL所包含的東西,因此Oracle在執行函數時,會頻繁在SQL上下文和PL/SQL上下文之間切換。當數據量大時,就會增加CPU和內存的消耗,降低語句執行的效率。
因此,自定義函數,就像一把雙刃劍一樣,擺在了我們面前。對此,我們有以下幾種對策:
1、不用函數
2、借用Oracle的緩存機制
3、函數索引
1)不用函數。不用函數確實能解決問題,但如果一段邏輯會被很多個SQL語句用到,這就會給我們的代碼管理帶來了很大的麻煩。因此這是萬不得已的下下策。當然,沒必要使用函數的地方,可以盡量避免。
2)借用Oracle的緩存機制。
Oracle對子查詢,是會做緩存處理的。因此我們可以把函數寫在一個子查詢中,如把“my_func(id)”變成“(select my_func(id) from dual)”。這樣做可以通過緩存,減少函數被調用的次數,從而提高效率。通常用函數對大數據量進行過濾時,此方法都可大量降低函數被調用的次數(可從Oracle的執行統計看出)
另一種方法,就是對函數強行開啟結果緩存。方法是在函數的return類型之后,加上“result_cache”標記。
3)使用函數索引。首先該函數必須被標記為deterministic,即在函數的return類型之后,加上“deterministic”標記。它表示當函數的輸入值是確定時,返回結果必定是唯一的。此后,在表的列上新建索引,索引列不是寫列名,而是寫“my_func(id)”這樣即可。
通常地,我推薦先嘗試“子查詢緩存”這種方法。因為它不僅對函數、表本身沒有作任何修改,而且效果也比較明顯。我曾經試過對一條很復雜的SQL做了這種處理,結果執行效率提高了60倍之多!如果緩存效果不明顯時,可以再嘗試下函數索引。不過我發現同樣的SQL,我只加函數索引的話,效果并不如“子查詢緩存”那樣立竿見影。
注意,以上提到的,都只是一些調優的手段而已,并非一定能解決問題。所以可以的話,我們還是要盡量避免把函數放在where語句中。
額。。。oracle是沒有預熱的。如果你要預熱的話,建議做一次“第八套全國廣播體操”,預備~起~1234~2234...
用 row_number()over(partition by 客戶 order by 客戶 asc,
提貨時間 desc) rn,然后取第一條數據就好了。
1、我們在Sql Plus中,我們利用Create User關鍵字進行用戶創建。
2、此時,我們就可以在Create User后面,指定用戶名稱。
3、這時候,我們就可以在這里利用Indentified By關鍵字引導。
4、引導我們當前新建的用戶指定與Test。
5、這時候,我們按下回車,就可以看到我們新家你的Angela用戶成功創建。
6、這時候,我們就能對Dba_Users表進行查詢是否創建成功。
當前題目:oracle如何做預熱,如何做活動預熱
本文路徑:http://vcdvsql.cn/article14/dsigede.html
成都網站建設公司_創新互聯,為您提供云服務器、營銷型網站建設、品牌網站制作、電子商務、品牌網站設計、響應式網站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯