Oracle的自定義函數(shù),提供了對邏輯的封裝能力,便于我們對代碼進行管理。然而當這個函數(shù)出現(xiàn)在where語句中,它卻很可能給我們的SQL語句帶來嚴重的效率問題。因為:
成都創(chuàng)新互聯(lián)公司專業(yè)提供成都主機托管四川主機托管成都服務器托管四川服務器托管,支持按月付款!我們的承諾:貴族品質(zhì)、平民價格,機房位于中國電信/網(wǎng)通/移動機房,川西大數(shù)據(jù)中心服務有保障!
1、Oracle的優(yōu)化器無法對函數(shù)進行優(yōu)化,只能逐行執(zhí)行(這就是為什么我們常發(fā)現(xiàn),把函數(shù)里面的語句拷出來,就會執(zhí)行得很快的原因)
2、函數(shù)并非標準SQL所包含的東西,因此Oracle在執(zhí)行函數(shù)時,會頻繁在SQL上下文和PL/SQL上下文之間切換。當數(shù)據(jù)量大時,就會增加CPU和內(nèi)存的消耗,降低語句執(zhí)行的效率。
因此,自定義函數(shù),就像一把雙刃劍一樣,擺在了我們面前。對此,我們有以下幾種對策:
1、不用函數(shù)
2、借用Oracle的緩存機制
3、函數(shù)索引
1)不用函數(shù)。不用函數(shù)確實能解決問題,但如果一段邏輯會被很多個SQL語句用到,這就會給我們的代碼管理帶來了很大的麻煩。因此這是萬不得已的下下策。當然,沒必要使用函數(shù)的地方,可以盡量避免。
2)借用Oracle的緩存機制。
Oracle對子查詢,是會做緩存處理的。因此我們可以把函數(shù)寫在一個子查詢中,如把“my_func(id)”變成“(select my_func(id) from dual)”。這樣做可以通過緩存,減少函數(shù)被調(diào)用的次數(shù),從而提高效率。通常用函數(shù)對大數(shù)據(jù)量進行過濾時,此方法都可大量降低函數(shù)被調(diào)用的次數(shù)(可從Oracle的執(zhí)行統(tǒng)計看出)
另一種方法,就是對函數(shù)強行開啟結(jié)果緩存。方法是在函數(shù)的return類型之后,加上“result_cache”標記。
3)使用函數(shù)索引。首先該函數(shù)必須被標記為deterministic,即在函數(shù)的return類型之后,加上“deterministic”標記。它表示當函數(shù)的輸入值是確定時,返回結(jié)果必定是唯一的。此后,在表的列上新建索引,索引列不是寫列名,而是寫“my_func(id)”這樣即可。
通常地,我推薦先嘗試“子查詢緩存”這種方法。因為它不僅對函數(shù)、表本身沒有作任何修改,而且效果也比較明顯。我曾經(jīng)試過對一條很復雜的SQL做了這種處理,結(jié)果執(zhí)行效率提高了60倍之多!如果緩存效果不明顯時,可以再嘗試下函數(shù)索引。不過我發(fā)現(xiàn)同樣的SQL,我只加函數(shù)索引的話,效果并不如“子查詢緩存”那樣立竿見影。
注意,以上提到的,都只是一些調(diào)優(yōu)的手段而已,并非一定能解決問題。所以可以的話,我們還是要盡量避免把函數(shù)放在where語句中。
額。。。oracle是沒有預熱的。如果你要預熱的話,建議做一次“第八套全國廣播體操”,預備~起~1234~2234...
用 row_number()over(partition by 客戶 order by 客戶 asc,
提貨時間 desc) rn,然后取第一條數(shù)據(jù)就好了。
1、我們在Sql Plus中,我們利用Create User關鍵字進行用戶創(chuàng)建。
2、此時,我們就可以在Create User后面,指定用戶名稱。
3、這時候,我們就可以在這里利用Indentified By關鍵字引導。
4、引導我們當前新建的用戶指定與Test。
5、這時候,我們按下回車,就可以看到我們新家你的Angela用戶成功創(chuàng)建。
6、這時候,我們就能對Dba_Users表進行查詢是否創(chuàng)建成功。