• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            無我

            讓內(nèi)心永遠(yuǎn)燃燒著偉大的光明的精神之火!
            靈活的思考,嚴(yán)謹(jǐn)?shù)膶崿F(xiàn)
            豪邁的氣魄、頑強(qiáng)的意志和周全的思考

            PL/SQL學(xué)習(xí)——過程和函數(shù)

               PL/SQL塊主要有兩種類型,即命名塊和匿名塊。匿名塊(以DECLARE或BEGIN開始)每次使用時都要進(jìn)行編譯,除此之外,該類塊不在數(shù)據(jù)庫中存儲并且不能直接從其他的PL/SQL塊中調(diào)用。過程,函數(shù),包和觸發(fā)器都屬于命名塊,這類構(gòu)造沒有匿名塊的限制,它們可以存儲在數(shù)據(jù)庫中并在適當(dāng)?shù)臅r候運行。

            創(chuàng)建子程序:
               PL/SQL的過程和函數(shù)的運行方式非常類似于其他3GL(第3代程序設(shè)計語言)使用的過程和函數(shù)。它們之間具有許多共同的特征屬性。總起來說,過程和函數(shù)統(tǒng)稱為子程序。兩者不同的是,過程調(diào)用本身是一個PL/SQL語句,而函數(shù)調(diào)用是作為表達(dá)式的一部分執(zhí)行的。
               創(chuàng)建過程的語法如下所示:
            CREATE [OR REPLACE] PROCEDURE procedure_name
            [ ( argument[{IN | OUT | IN OUT}] type] {IS | AS}
            /* Declarative section is here */
            BEGIN
            /* Executable section is here */
            EXCEPTION
            /* Exception section is here */
            END [ procedure_name];
               創(chuàng)建函數(shù)的語法如下所示:
            CREATE [OR REPLACE] FUNCTION function_name
            [( argument[{IN | OUT | IN OUT}] type]
            RETURN return_type {IS | AS}
            BEGIN
            /* Executable section is here */
            RETURN expression;
            EXCEPTION
            /* Exception section is here */
            END [ function_name];
               過程和函數(shù)的參數(shù)表都是可選的,并且函數(shù)聲明部分和函數(shù)調(diào)用都沒有使用括弧。然而,由于函數(shù)調(diào)用是表達(dá)式的一部分,所以函數(shù)返回類型是必須要有的。函數(shù)的類型可以用來確定包含函數(shù)調(diào)用的表達(dá)式的類型。

            過程和函數(shù)的撤消:
               撤消過程的語法是:DROP PROCEDURE procedure_name;
               撤消函數(shù)的語法是:DROP FUNCTION function_name;

            子程序參數(shù):
               子程序形參可以有三種模式:IN,OUT或IN OUT。(Oracle8i增加了NOCOPY限定符)如果沒有為形參指定模式,其默認(rèn)模式為IN。模式說明如下:
            IN :當(dāng)過程被調(diào)用時,實參的值將傳入該過程。在該過程內(nèi)部,形參類似PL/SQL使用的常數(shù),即該值具有只讀屬性不能對其修改。當(dāng)該過程結(jié)束時,控制將返回到調(diào)用環(huán)境,這
            時,對應(yīng)的實參沒有改變。
            OUT :當(dāng)過程被調(diào)用時,實參具有的任何值將被忽略不計。在該過程內(nèi)部,形參的作用類似沒有初始化的PL/SQL變量,其值為空(NULL)。該變量具有讀寫屬性。當(dāng)該過程結(jié)束時,控制將返回調(diào)用環(huán)境,形參的內(nèi)容將賦予對應(yīng)的實參。(在Oracle8i中,該操作可由NOCOPY變更。)
            IN OUT :該模式是模式IN和OUT的組合。當(dāng)調(diào)用過程時,實參的值將被傳遞到該過程中。在該過程內(nèi)部,形參相當(dāng)于初始化的變量,并具有讀寫屬性。當(dāng)該過程結(jié)束時,控制將返回到調(diào)用環(huán)境中,形參的內(nèi)容將賦予實參(在Oracle8i中與參數(shù)NOCOPY有關(guān))。
               Oracle8i提供了一個叫做NOCOPY的編譯選項。使用該項聲明參數(shù)的語法如下:
               parameter_name [mode] NOCOPY datatype
               其中parameter_name是參數(shù)名,mode是參數(shù)的模式(IN ,OUT ,IN OUT),datatype是參數(shù)的數(shù)據(jù)類型。如果使用了NOCOPY,則PL/SQL編譯器將按引用傳遞參數(shù),而不按值傳遞。當(dāng)參數(shù)按引用傳遞時,任何對實參的修改也將引起對其對應(yīng)形參的修改,這是因為該實參和形參同時位于相同的存儲單元的緣故。
               在某些情況下,NOCOPY將被編譯器忽略,這時的參數(shù)仍將按值傳遞。這時,編譯器不會報告編譯錯誤。由于NOCOPY是一個提示項(Hint),編譯器可以決定是否執(zhí)行該項。
               NOCOPY的主要優(yōu)點是可以提高程序的效率。當(dāng)我們傳遞大型PL/SQL表時,其優(yōu)越性特別顯著。
            過程和函數(shù)有許多相同的特點:
               1、通過設(shè)置OUT參數(shù),過程和函數(shù)都可以返回一個以上的值。
               2、過程和函數(shù)都可以具有聲明部分、執(zhí)行部分,以及異常處理部分。
               3、過程和函數(shù)都可以接收默認(rèn)值。
               4、都可以使用位置或名稱對應(yīng)法調(diào)用過程和函數(shù)。
               5、過程和函數(shù)都可以接受參數(shù)NOCOPY。

            過程和函數(shù)的選擇:
               對于什么時候使用函數(shù)更合適,什么時候使用過程更有效這一問題,一般來說,過程和函數(shù)的使用與子程序?qū)⒁祷氐闹档臄?shù)量以及這些值的使用方法有關(guān):通常,如果返回值在一個以上,用過程為好。如果只有一個返回值,使用函數(shù)就可以滿足要求。盡管函數(shù)可以合法的使用參數(shù)OUT,但這種做法通常不予考慮。除此之外,函數(shù)還可以在SQL語句中調(diào)用。

            posted on 2013-04-10 15:15 Tim 閱讀(418) 評論(0)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)庫

            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            導(dǎo)航

            統(tǒng)計

            公告

            本博客原創(chuàng)文章,歡迎轉(zhuǎn)載和交流。不過請注明以下信息:
            作者:TimWu
            郵箱:timfly@yeah.net
            來源:www.shnenglu.com/Tim
            感謝您對我的支持!

            留言簿(9)

            隨筆分類(173)

            IT

            Life

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            久久久久国产视频电影| 无码人妻久久久一区二区三区| 亚洲精品乱码久久久久久蜜桃不卡| 人妻中文久久久久| 国产一级做a爰片久久毛片| 久久毛片免费看一区二区三区| 日韩人妻无码一区二区三区久久99| 亚洲AV乱码久久精品蜜桃| 精品国产乱码久久久久久1区2区 | 亚洲?V乱码久久精品蜜桃 | 漂亮人妻被中出中文字幕久久| 少妇人妻88久久中文字幕| 国产三级观看久久| 久久99热国产这有精品| 狠狠色丁香久久婷婷综合_中| 亚洲国产成人久久精品影视| 久久国产精品一国产精品金尊| 久久久这里有精品| 久久精品国产一区二区三区不卡 | 中文精品久久久久国产网址| 一个色综合久久| 久久国产精品一区| 青青草原综合久久大伊人精品| 高清免费久久午夜精品| 97久久超碰成人精品网站| 久久久久久久精品妇女99| 亚洲AV无码久久精品蜜桃| 亚洲国产成人精品女人久久久 | 久久久高清免费视频| 久久99精品国产麻豆不卡| 久久涩综合| 久久久久九国产精品| 国产叼嘿久久精品久久| 国产AV影片久久久久久| 精品一区二区久久| 97r久久精品国产99国产精| 久久久久久亚洲AV无码专区| 久久综合给合久久国产免费| 久久九九有精品国产23百花影院| 91视频国产91久久久| 亚洲欧美日韩精品久久|