一、与存储过程的区别:
存储过程:可有0个返回,也可多个返回;适合做批量插入、批量更新;
函数:有且仅有1个返回值;适合做处理数据后返回一个结果。
二、创建:
create function 函数名(参数列表) returns 返回类型
begin
函数体
end
注意:
1、参数列表:包含参数名和参数类型
2、函数体:定有return语句,若没有会报错;若return语句没有放在函数体的最后也不报错,但不建议。
3、函数体中只有一条语句,则可省略begin、end;
4、使用delimiter语句设置结束标记。
二、调用:
select 函数名(参数列表)
四、案例:
1、无参有返回:
#案例:返回公司的员工个数;
create function myf1() returns int
begin
declare c int default 0; # 定义变量
select count(*) into c # 赋值
from employees;
return c;
end $
select myf1() $
2、有参有返回:
#案例:根据员工名返回其工资;
create function myf2(empName varchar(20)) returns double
begin
set @sal = 0; #定义用户变量
select salary into @sal # 赋值
from employees
where lastName = empName;
return @sal;
end $
select myf2('john') $
#案例:根据部门名,返回该部门的平均工资;
create function myf3(deptName varchar(20)) returns double
begin
declare sal double; # 声明变量
select avg(salary) into sal
from employees e
join departments d on e.departmentId = d.departmentId
where d.departmentName = deptName;
return sal;
end $
select myf3('IT') $
五、查看函数:
show create function myf3;
六、删除函数:
drop function myf3;