猿问

请问在oracle中 procedure和function有何本质区别?

oracle中 procedure和function有何本质区别?


尚方宝剑之说
浏览 627回答 4
4回答

守着一只汪

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

jeck猫

1、标识符不同。函数的标识符为FUNCTION,过程为:PROCEDURE。2、函数中一般不用变量形参,用函数名直接返回函数值;而过程如有返回值,则必须用变量形参返回。3、过程无类型,不能给过程名赋值;函数有类型,最终要将函数值传送给函数名。4、函数在定义时一定要进行函数的类型说明,过程则不进行过程的类型说明。5、调用方式不同。函数的调用出现在表达式中,过程调用,由独立的过程调用语句来完成。6、过程一般会被设计成求若干个运算结果,完成一系列的数据处理,或与计算无关的各种操作;而函数往往只为了求得一个函数值

翻阅古今

Function:函数,可以带返回值语法:Sub SubName(参数1, 参数2,...)....End SubFunction FunctionName(参数1, 参数2,...)...FunctionName = 返回值End Function调用方法:Sub直接用 SubName 参数1, 参数2,...Function如果不要返回值用 FunctionName 参数1, 参数2,...如果要返回值 Result = FunctionName(参数1, 参数2,...)语法是这样,这是对的Sub SubName(参数1, 参数2,...)....End SubFunction 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 codeNameOfFunction = return valueEnd Function

阿波罗的战车

Function: 函数(有返回值且必须返回)Procedure: 过程(可以无返回,也可以返回值或返回表)Package: 包(相当于一个容器,将逻辑上相关的函数、过程、变量、常量和游标组合成一个更大的单位)
随时随地看视频慕课网APP

相关分类

Oracle
MySQL
我要回答