存儲過程:?
語法:CREATE [OR REPLACE] PROCEDURE procedure_name(arg1 [in、out、in out] datatype1,..) IS [AS] PL/SQL block;
語法解析:in(輸入參數):當沒有參數模式時,系統默認為in,在過程中不能對其賦值。
out(輸出參數):過程中需對其賦值,類似于函數中的返回值,在外部調用時可以接受到,并且可以聲明多個輸出參數。
in out(輸入輸出參數):是以上兩個參數模式的結合,既可以賦值,又可以輸出。
參數傳遞:
一:位置傳遞:傳入的值必須和過程的參數列表的類型、順序一致。
二:名稱傳遞:在調用過程的時候,可以將過程的使用(參數名=>值)來對指定的參數傳值。
三:組合傳遞:結合以上兩種傳遞:既可以對應位置,有可以使用參數名傳值。
參數:
語法:CREATE [OR REPLACE] FUNCTION function_name RETURN DATATYPE IS 參數定義區 BEIGN 函數體 END;
與過程相比:函數必須要返回類型。其他與過程相似。
函數調用限制:
函數可以在以下部分調用:SELECT 命令的選擇列表;
????? WHERE和HAVING子句中;
????????????????????? CONNECT BY,START WITH,ORDER BY 以及GROUP BY子句中;
????????????????????? INSERT 命令的VALUES子句中;
????????????????????? UPDATE命令的SET子句中;
函數的在以下的情況限制調用:在SQL語句中只能調用存儲過程(服務器端),而不能調用客戶端的函數;
????????????????????????? 在SQL語句中調用的函數只能帶有輸入參數(IN),而不能帶有輸出參數(OUT)和輸入輸出參數(IN OUT);
????????????????? 在SQL語句中調用的函數只能使用SQL所支持的標準數據類型,而不能使用PL/SQL的特有數據類型(例如:TABLE和RECORD等);
????????????????????????? 在SQL語句中調用的函數不能包含INSERT,UPDATE和DELETE語句;
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
