闲话少叙进入正题,起始函数与存储过程基本相似。下面先通过对比两者的不同点,来初步认识一下:
关键字的不同;存储过程是procedure。函数是function。
对于参数的支持;存储过程支持输入参数(in)、输出参数(out)。函数只支持输入参数(通过API及手册,没有明确提到支持输出参数。在做Demo时,曾尝试在参数前添加关键字out,但提示语法错误)。
对于返回值的要求:存储过程可以无返回值、也可以有返回值,并且返回值的结果中支持结果集。函数必须设置返回值。
在执行中,函数支持通过select执行,如select fun_Test1();而存储过程不可以。
有关嵌套的问题;因为在实际开发中可能涉及到嵌套。在mySql中两者是支持多层嵌套的。在MsSql中存储过程不支持多层嵌套(2层以内)。
delimiter $$
drop function if exists fun_Test1$$
create function fun_Test1
(
_para1 int,
_para2 int
)
returns int DETERMINISTIC READS SQL DATA
begin
return _para1+_para2;
end$$
delimiter ;这里边还要注意一下,在returns 后的那句话“DETERMINISTIC READS SQL DATA”。这里需要明确指出你的函数操作类型。具体内容如下:-- CONTAINS SQL表示子程序不包含读或写数据的语句;
-- NO SQL表示子程序不包含SQL语句。
-- READS SQL DATA表示子程序包含读数据的语句,但不包含写数据的语句。
-- MODIFIES SQL DATA表示子程序包含写数据的语句。
如有不周之处,还请批评指正。
最佳答案