自定義函數
用戶自定義函數(user-defined function,UDF)是一種對MySQL擴展的途徑,其用法與內置函數相同
自定義函數的兩個必要條件:
1.參數
2.返回值
函數可以返回任意類型的值,同樣可以接受這些類型的參數
創建自定義函數
image.png
關于函數體
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 + 內容
image.png
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語句