MySql自定义函数的定义和使用

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状态的函数

你可能感兴趣的:(MySql基础篇)