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