存儲(chǔ)過程:?
語法:CREATE [OR REPLACE] PROCEDURE procedure_name(arg1 [in、out、in out] datatype1,..) IS [AS] PL/SQL block;
語法解析:in(輸入?yún)?shù)):當(dāng)沒有參數(shù)模式時(shí),系統(tǒng)默認(rèn)為in,在過程中不能對(duì)其賦值。
out(輸出參數(shù)):過程中需對(duì)其賦值,類似于函數(shù)中的返回值,在外部調(diào)用時(shí)可以接受到,并且可以聲明多個(gè)輸出參數(shù)。
in out(輸入輸出參數(shù)):是以上兩個(gè)參數(shù)模式的結(jié)合,既可以賦值,又可以輸出。
參數(shù)傳遞:
一:位置傳遞:傳入的值必須和過程的參數(shù)列表的類型、順序一致。
二:名稱傳遞:在調(diào)用過程的時(shí)候,可以將過程的使用(參數(shù)名=>值)來對(duì)指定的參數(shù)傳值。
三:組合傳遞:結(jié)合以上兩種傳遞:既可以對(duì)應(yīng)位置,有可以使用參數(shù)名傳值。
參數(shù):
語法:CREATE [OR REPLACE] FUNCTION function_name RETURN DATATYPE IS 參數(shù)定義區(qū) BEIGN 函數(shù)體 END;
與過程相比:函數(shù)必須要返回類型。其他與過程相似。
函數(shù)調(diào)用限制:
函數(shù)可以在以下部分調(diào)用:SELECT 命令的選擇列表;
????? WHERE和HAVING子句中;
????????????????????? CONNECT BY,START WITH,ORDER BY 以及GROUP BY子句中;
????????????????????? INSERT 命令的VALUES子句中;
????????????????????? UPDATE命令的SET子句中;
函數(shù)的在以下的情況限制調(diào)用:在SQL語句中只能調(diào)用存儲(chǔ)過程(服務(wù)器端),而不能調(diào)用客戶端的函數(shù);
????????????????????????? 在SQL語句中調(diào)用的函數(shù)只能帶有輸入?yún)?shù)(IN),而不能帶有輸出參數(shù)(OUT)和輸入輸出參數(shù)(IN OUT);
????????????????? 在SQL語句中調(diào)用的函數(shù)只能使用SQL所支持的標(biāo)準(zhǔn)數(shù)據(jù)類型,而不能使用PL/SQL的特有數(shù)據(jù)類型(例如:TABLE和RECORD等);
????????????????????????? 在SQL語句中調(diào)用的函數(shù)不能包含INSERT,UPDATE和DELETE語句;
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061
微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元

