1.MySQL自定义函数简介
在MySQL中使用自定义函数也需要相应的要求,语法如下,
创建新函数:
Create function function_name(参数列表)
returns返回值类型
函数体内容
- 函数名:应该合法的标识符,并且不应该与已有的关键字冲突。一个函数应该属于某数据库,可以使用db_name.funciton_name的形式执行当前函数所属数据库
,否则默认为当前数据库。
- 参数列表:可以有一个或者多个函数参数,甚至是没有参数也是可以的。对于每个参数,由参数名和参数类型组成。
- 返回值:指明返回值类类型
- 函数体:自定义函数的函数体由多条可用的MySQL语句,流程控制,变量声明等语句构成。需要指明的是函数体中一定要含有return 返回语句。
2.自定义示例
A.无参函数定义
mysql> DROP FUNCTION IF EXISTS hello;
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> DELIMITER $$
mysql> CREATE FUNCTION hello()
-> RETURNS VARCHAR(255)
-> BEGIN
-> RETURN 'Hello God,i am mysql';
-> END $$
Query OK, 0 rows affected (0.11 sec)
mysql> DELIMITER ;
mysql> SELECT hello();
+-------------------------+
| hello() |
+-------------------------+
| Hello world,i am mysql |
+-------------------------+
row in set (0.00 sec)
调用自定义函数也非常的简单 如上所示:
之所以使用DELIMITER是因为MySQL中默认是使用分号来结束一个命令的,我们定义的函数体中一条命令写完时会用分号来结束,而MySQL会误以为函数体已经定义完成,因为我们需要定义一个新的标识符来标识一个命令的结束,因为就可以使用DELIMITER。
B:含有参数的自定义函数
在我们格式化日期的时候我们会调用DATE_FORMAT(date,format)函数,第一个参数是日期第二个参数是需要格式化的格式,也就是说需要传递两个参数,我们现在就把这个函数给改下
mysql> DELIMITER $$
mysql> DROP FUNCTION IF EXISTS test.formatDate $$
Query OK, 0 rows affected, 1 warning (0.07 sec)
mysql> CREATE FUNCTION test.formatDate(fdate datetime)
-> RETURNS VARCHAR(255)
-> BEGIN
-> DECLARE x VARCHAR(255) DEFAULT '';
-> SET x= date_format(fdate,'%Y年%m月%d日%h时%i分%s秒');
-> RETURN x;
-> END $$
Query OK, 0 rows affected (0.11 sec)
mysql> DELIMITER ;
mysql> SELECT formatDate(now());
+----------------------------+
| formatDate(now()) |
+----------------------------+
| 2018年07月10日12时41分21秒 |
+----------------------------+
row in set (0.18 sec)
3.其他相关
1.删除函数我们可以使用 DROP FUNCTION IF EXISTS function_name;
2. show function status [like 'pattern']; -- 查看所有自定义函数, 自定义函数只能在本数据库使用。
3. show create function 函数名; -- 查看函数创建语句
CREATE FUNCTION `queryAppStatus`(pkApp VARCHAR(64))
RETURNS varchar(300)
BEGIN
DECLARE appLvl VARCHAR(300); -- 定义一个局部变量
DECLARE statu VARCHAR(3000);
SELECT app_lvl INTO appLvl FROM app WHERE pk_app = pkApp;
IF appLvl = '5' THEN
SELECT STATUS INTO statu FROM sp_app_audit WHERE pk_app = pkApp;
ELSE
SET statu = '0';
END IF;
RETURN statu ;
END
以上定义一个查询app状态的函数