自定义函数
用户自定义函数(user-defined function,UDF)是一种对MySQL扩展的途径,其用法与内置函数相同
自定义函数的两个必要条件:
1.参数
2.返回值
函数可以返回任意类型的值,同样可以接受这些类型的参数
创建自定义函数
关于函数体
1.函数体由合法的SQL语句构成
2.函数体可以是简单的select或insert语句
3.函数体如果为复合结构则使用begin...end语句
4.复合结构可以包含声明,循环,控制结构
mysql> create function f1() returns varchar(30)
-> return date_format(now(),'%Y年%m月%d日 %H点:%i分:%s秒');
Query OK, 0 rows affected (0.00 sec)
mysql> select f1();
+-------------------------------------+
| f1() |
+-------------------------------------+
| 2018年03月09日 10点:43分:30秒 |
+-------------------------------------+
1 row in set (0.00 sec)
ps 先要修改编码方式
mysql> set names utf8;
然后还有删除函数的方法
mysql> drop function f1;
mysql> create function f2(num1 smallint unsigned,num2 smallint unsigned)
-> returns float(10,2) unsigned
-> return (num1+num2)/2;
Query OK, 0 rows affected (0.01 sec)
mysql> select f2(10,5);
+----------+
| f2(10,5) |
+----------+
| 7.50 |
+----------+
1 row in set (0.02 sec)
returns + 类型
return + 内容
mysql> delimiter // //修改结束符为'//'
mysql> create function adduser(first_name varchar(20))
-> returns int unsigned
-> begin
-> insert test(first_name)values(first_name);
-> return last_insert_id();
-> end
-> //
ps 假如有两条以上的语句就要使用begin...end语句