Mysql中自定义函数的创建和执行

假设students表中包含id和name两个字段,创建一个函数,函数的作用是根据id查找name

1、创建表,插入数据

create table students(id int,name varchar(100));
insert into students(id,name) values(1,'annie'),(2,'bell'),(3,'danny');

2、创建函数

DELIMITER //
create function find_student(id int) returns varchar(100)
READS SQL DATA
begin
	declare sname varchar(100) default '';
    select students.name into sname from students where students.id=id;
    return sname;
end //
DELIMITER ;

需要注意的事项
1)使用DELIMITER//修改分隔符
mysql的默认语句结束符号是分号,当mysql遇到分号时就自动执行当前语句。因为函数定义时包含多条sql语句,所以使用DELIMITER //先将分隔符设置为//,等函数创建语句完成后,再将分隔符改回分号即可。

2)READS SQL DATA
之前我没写这句话,但是创建时mysql报错,提示Error Code: 1418. 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)
上网查了一下,意思是没有声明mysql函数的类型:

mysql开启了bin-log, 我们就必须指定我们的函数是否是哪种类型:
1 DETERMINISTIC 不确定的
2 NO SQL 没有SQl语句,当然也不会修改数据
3 READS SQL DATA 只是读取数据,当然也不会修改数据
4 MODIFIES SQL DATA 要修改数据
5 CONTAINS SQL 包含了SQL语句
所以我加上了READS SQL DATA

3)使用局部变量
变量定义:我这里使用declare sname varchar(100) default ‘’;定义了局部变量sname,
变量使用:
可以使用select students.name into sname from students where students.id=id;为变量赋值
也可以直接使用set语句来赋值,如set sname=‘test’

3、执行函数:select 函数名(参数值);

select find_student(3);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值