青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

無我

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

PL/SQL學習——過程和函數(shù)

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

創(chuàng)建子程序:
   PL/SQL的過程和函數(shù)的運行方式非常類似于其他3GL(第3代程序設計語言)使用的過程和函數(shù)。它們之間具有許多共同的特征屬性。總起來說,過程和函數(shù)統(tǒng)稱為子程序。兩者不同的是,過程調(diào)用本身是一個PL/SQL語句,而函數(shù)調(diào)用是作為表達式的一部分執(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)用是表達式的一部分,所以函數(shù)返回類型是必須要有的。函數(shù)的類型可以用來確定包含函數(shù)調(diào)用的表達式的類型。

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

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

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

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

<2013年7月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910

導航

統(tǒng)計

公告

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

留言簿(9)

隨筆分類(173)

IT

Life

搜索

積分與排名

最新隨筆

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美在线免费| 亚洲人在线视频| 国产精品影院在线观看| 欧美日韩国产va另类| 欧美日韩成人综合在线一区二区| 免费观看在线综合色| 亚洲一区二区三区国产| 中文亚洲欧美| 性色av一区二区三区| 亚洲永久精品大片| 欧美一乱一性一交一视频| 久久久精品国产免费观看同学| 久久亚洲风情| 欧美日韩一区二区在线观看| 国产麻豆日韩| 亚洲第一区在线观看| 一区二区三区不卡视频在线观看| 亚洲欧美文学| 欧美黄色影院| av不卡在线观看| 久久激情综合| 欧美精品在线视频观看| 国产伦精品一区二区三区免费| 在线观看三级视频欧美| 亚洲一区综合| 欧美二区在线| 亚洲欧美色一区| 欧美精品免费播放| 黑人巨大精品欧美一区二区| 在线午夜精品自拍| 免费亚洲一区| 性久久久久久久久| 欧美福利网址| 一区二区三区中文在线观看| 欧美成人精品影院| 国产精品v欧美精品v日本精品动漫| 国产精品a久久久久久| 亚洲福利在线看| 欧美一区综合| 亚洲午夜精品17c| 欧美风情在线观看| 在线播放一区| 久久蜜桃资源一区二区老牛 | 久久―日本道色综合久久| 亚洲国产精品一区二区第四页av| 亚洲欧美国产日韩中文字幕| 欧美激情中文字幕乱码免费| 在线观看91精品国产入口| 欧美伊人久久| 亚洲制服少妇| 国产精品日韩在线| 香蕉尹人综合在线观看| 99精品视频免费观看视频| 欧美成人精品一区| 亚洲乱码日产精品bd| 亚洲国产婷婷香蕉久久久久久99| 久久综合亚洲社区| 亚洲电影下载| 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲人久久久| 欧美日韩成人网| 一区二区高清在线| 日韩亚洲欧美综合| 欧美视频中文字幕| 性欧美xxxx大乳国产app| 99视频在线观看一区三区| 欧美日韩三级在线| 亚洲综合三区| 亚洲欧美日韩网| 狠狠入ady亚洲精品| 欧美69视频| 欧美激情在线观看| 亚洲你懂的在线视频| 亚洲一区在线视频| 合欧美一区二区三区| 亚洲国内欧美| 国产精品欧美精品| 男人插女人欧美| 欧美高清不卡| 亚洲麻豆国产自偷在线| 亚洲伦伦在线| 国产亚洲精品7777| 亚洲电影av在线| 欧美亚日韩国产aⅴ精品中极品| 午夜亚洲福利| 另类尿喷潮videofree| 中国女人久久久| 欧美在线亚洲综合一区| 亚洲人妖在线| 欧美中文在线视频| 久久久久久亚洲综合影院红桃| 夜夜嗨av色一区二区不卡| 欧美成人情趣视频| 国产精品xxxxx| 欧美呦呦网站| 欧美电影资源| 久久九九国产| 欧美日韩1区2区| 美女精品在线观看| 国产精品久久国产愉拍| 久久久www成人免费精品| 久久伊人免费视频| 香蕉乱码成人久久天堂爱免费| 免费欧美电影| 久久精品99国产精品| 欧美日韩免费视频| 欧美sm重口味系列视频在线观看| 欧美性猛交xxxx乱大交蜜桃| 欧美福利电影网| 国产一区二区三区免费观看| 一本色道久久综合狠狠躁篇怎么玩| 一区在线免费| 午夜亚洲影视| 亚洲欧美制服另类日韩| 欧美激情综合色| 欧美国产在线电影| 国内成+人亚洲| 午夜精品久久久久久久男人的天堂| 99视频精品| 欧美极品影院| 亚洲精品1区| 亚洲国产欧美日韩另类综合| 欧美尤物一区| 欧美专区在线观看一区| 国产精品成人免费| 欧美日韩直播| 伊人久久综合97精品| 久久狠狠婷婷| 欧美综合国产| 国产视频精品免费播放| 亚洲——在线| 午夜视黄欧洲亚洲| 国产美女一区| 亚洲欧美日韩成人| 欧美亚洲尤物久久| 欧美性色aⅴ视频一区日韩精品| 最新国产の精品合集bt伙计| 亚洲人成人77777线观看| 欧美成人在线网站| 亚洲人成7777| 亚洲午夜激情网页| 国产精品久久久久99| 亚洲一区影院| 久久精品男女| 国内揄拍国内精品久久| 久久精品1区| 欧美激情第二页| 一区二区激情| 国产精品久久久免费| 香蕉久久夜色精品国产使用方法| 久久嫩草精品久久久精品一| 亚洲第一精品夜夜躁人人爽| 美女任你摸久久| 99成人在线| 欧美在线一二三四区| 在线成人黄色| 欧美激情综合在线| 小黄鸭精品aⅴ导航网站入口| 国产麻豆91精品| 久久色中文字幕| 亚洲精品一区在线观看香蕉| 一区二区三区欧美在线| 欧美成人官网二区| 亚洲视频网站在线观看| 久久日韩粉嫩一区二区三区| 亚洲人成人一区二区在线观看| 欧美色123| 久久精品国产综合精品| 91久久国产综合久久91精品网站| 亚洲特级毛片| 国内精品视频在线播放| 欧美大片在线看| 亚洲欧美欧美一区二区三区| 欧美成人一区二区三区片免费| 一区二区三区高清在线观看| 国产日韩精品一区二区三区在线 | 亚洲综合色丁香婷婷六月图片| 国产一区二区三区四区三区四| 免费在线成人av| 亚洲在线视频网站| 亚洲二区精品| 久久成人综合视频| 在线视频欧美日韩精品| 136国产福利精品导航| 欧美午夜视频网站| 免费观看一区| 久久久精品国产免大香伊| 亚洲无限av看| 亚洲精品一区二区三区99| 久久夜色精品国产亚洲aⅴ| 亚洲免费伊人电影在线观看av| 亚洲国产欧美在线| 国产欧美丝祙| 欧美手机在线| 欧美精品日本| 美女精品在线观看| 久久精品国产亚洲精品 | 香港久久久电影| 一区二区三区四区国产精品| 亚洲电影观看|