亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

請問在oracle中 procedure和function有何本質區別?

請問在oracle中 procedure和function有何本質區別?

尚方寶劍之說 2019-07-09 16:06:44
oracle中 procedure和function有何本質區別?
查看完整描述

4 回答

?
守著一只汪

TA貢獻1872條經驗 獲得超4個贊

function 可以使用在表達式中 x := func();procedure不能
function 可以做為表達式 select func() from dual;procedure 不能
function 不能BEGIN func();END;;procedure 可以

查看完整回答
反對 回復 2019-07-14
?
jeck貓

TA貢獻1909條經驗 獲得超7個贊

1、標識符不同。函數的標識符為FUNCTION,過程為:PROCEDURE。
2、函數中一般不用變量形參,用函數名直接返回函數值;而過程如有返回值,則必須用變量形參返回。
3、過程無類型,不能給過程名賦值;函數有類型,最終要將函數值傳送給函數名。
4、函數在定義時一定要進行函數的類型說明,過程則不進行過程的類型說明。
5、調用方式不同。函數的調用出現在表達式中,過程調用,由獨立的過程調用語句來完成。
6、過程一般會被設計成求若干個運算結果,完成一系列的數據處理,或與計算無關的各種操作;而函數往往只為了求得一個函數值

查看完整回答
反對 回復 2019-07-14
?
翻閱古今

TA貢獻1780條經驗 獲得超5個贊

Function:函數,可以帶返回值
語法:
Sub SubName(參數1, 參數2,...)
....
End Sub

Function FunctionName(參數1, 參數2,...)
...
FunctionName = 返回值
End Function

調用方法:
Sub直接用 SubName 參數1, 參數2,...
Function如果不要返回值用 FunctionName 參數1, 參數2,...
如果要返回值 Result = FunctionName(參數1, 參數2,...)

語法是這樣,這是對的
Sub SubName(參數1, 參數2,...)
....
End Sub

Function FunctionName(參數1, 參數2,...)
...
FunctionName = 返回值
End Function
調用時:
sub 只能用:
SubName 參數1, 參數2,...
函數則:
變量=FunctionName (參數1, 參數2,...)
FunctionName 參數1, 參數2,...
上面均未講出根本:
SUB與FUNCTION均可有返回值。所以首先要講清返回方式:有兩種,過程或函數返回,即分配與過程或函數同名的返回變量地址。function分配,但sub不分配。VB用此方式加以區分,VC則用VOID聲明不用分配。即如p=aa()若aa()是sub則什么也得不到,還會報錯。但函數則會得到數值。其次,參數返回,VB中缺省用地址傳參,即能返回。但聲明為BYVAL即值傳參,則不可返回,所以,不存在靈活性的差別。比如函數function bb(a,b), 調用時可以bb m, n也可以p=bb(m,n). 實際,如果確認不會失敗,才能用SUB,否則,必須要用FUNCTION以確認是否成功或取得返回值。所以編程,應少用SUB,少用 SubName 參數1, 參數2,...的調用方式。

sub是過程不需要返回值,function是函數,需要返回值,如下:
Function NameOfFunction(parameter1, parameter2)
'some code
NameOfFunction = return value
End Function



查看完整回答
反對 回復 2019-07-14
?
阿波羅的戰車

TA貢獻1862條經驗 獲得超6個贊

Function: 函數(有返回值且必須返回)
Procedure: 過程(可以無返回,也可以返回值或返回表)
Package: 包(相當于一個容器,將邏輯上相關的函數、過程、變量、常量和游標組合成一個更大的單位)

查看完整回答
反對 回復 2019-07-14
  • 4 回答
  • 0 關注
  • 674 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號