MySQL的函数

一、与存储过程的区别:

存储过程:可有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;

你可能感兴趣的:(MySQL)