MYSQL Function函数创建和调用

函数

存储过程类似,是一组预先变异好的SQL语句的集合

区别:

  • 存储过程:可有0个或多个返回。适合做批量插入、批量更新
  • 函数:有且仅有一个返回。适合做处理数据后返回一个结果

语法

一、创建语法

create function 函数名(参数列表) returns 返回类型
begin 
	函数体
End

注意:

  • 参数列表包含两部份:参数名+参数类型
  • 函数体:肯定会有return语句,如果没有会报错。如果return语句没有放在函数体的最后,也不报错,但是不建议。
  • 函数体中仅有一句话,则可以省略 Begin end
  • 使用delimiter语句设置结束标记

直接在 Navicat 里面创建函数:https://jingyan.baidu.com/article/09ea3ede5a0a37c0afde396e.html

二、调用语法

select 函数名(参数列表)

三、查看和删除

查看:show create function 函数名
删除: drop function 函数名

案例

案例 一:无参数有返回

问题:返回公司员工个数

create function myf1() returns int 
begin
		declare c int default 0; #定义变量
		select count(*) into c #为变量赋值
		from employee;
		return c;
End $

注意 这里创建函数时可能会遇到错误:ERROR 1418 (HY000): This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary
logging is enabled ( you * might* want to use the less safe
log_bin_trust_function_creators variable)

解决方式set global log_bin_trust_function_creators=TRUE;

创建完后
在这里插入图片描述
点开myf1函数,显示具体的内容
在这里插入图片描述

案例二:有参数有返回

create function myf2(employName VARCHAR(20)) returns DOUBLE
begin
		set @sal=0; #定义用户变量
		select salary into @sal
		from employees
		where last_name=employName;
		return @sal;
End $

select myfy2('员工名字')$
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值