自定义函数 (新手笔记二)

MySQL数据库提供了一些内置的函数,如数学函数、字符串函数等。但是往往在开发过程中,有些业务场景仅靠现有的内置函数并不能满足,这时就可以自定义函数,爱满足自己的业务需求。MySQL数据库设计的扩展性允许通过自定义函数的功能来解决这个问题。

函数的基本语法
1.创建自定义函数
CREATE FUNCTION function_name(参数列表),
RETURNS返回值类型
函数体内容

re

mysql >DELIMITER.$$
 mysql > CREATE FUNCTION fun(a1 varcahr(255))

(1)DELIMITER:是用来修改SQL语句的结束符,可以将结束符分号(;)修改为其他特殊字符,因为 在函数体内容里可以有多条SQL语句,是用分号(;)隔开的,代表该SQL语句结束,修改后的结束符在函数的末尾添加,代表定义函数完毕,所以要修改结束符。
(2)函数名:使用FUNCTION来标识函数,函数名应该是合法的标识符,不能与已有的关键字或函数冲突,一个函数是属于某数据库的,可以使用db_name.function.name 的形式来执行当前函数所属数据库。
(3) 参数列表:可以有0或多个参数,每个参数是由参数名和参数类型组成。
(4)RETURNS:指明函数要返回的类型。
(5) 函数体: 由多条可用的SQL语句,流程控制语句、变量声明等构成,函数体中一定要含有returns返回语句
(6)BEGIN…END:用来标识函数体的开始和结束,当有多条SQL语句时,可以使用BEGIN…END 来标识。
(7)DECLARE:声名变量,包括变量名和类型。
(8)SET 设置变量的值;
(9) RETURN:返回函数体内的返回值

二、增删查改 是必要的手段
(1)只能修改自定义函数的一些特性,不能修改函数体,如果要修改函数体,就需要删除函数来重新创建。
(2) function_name:函数的名称。
(3)characteristic参数:指存储函数的特性
(4) CONTAINS SQL:表示子程序包含SQL语句,但不包含读和写数据的语句。
(5)NO SQL:表示子程序中不包含SQL语句。
(6) READS SQL DATA:表示子程序包括可读SQL语句。
(7)MODIFIES SQL DATA:表示子程序中包含写数据的语句。
(8) SQL SECURITY { DEFINER | INVOKER} :指明谁有权限来执行。
(9) DEFINER:表示只有定义者自己才能够执行。
(10)INVOKER:表示调用者可以执行。
(11)COMMENT ‘string’:表示注释信息

 删 DROP FUNCTION fun;  
 修改: ALTER FUNCTION function _name[characteristic...]
     MYSQL>ALTER FUNCTION fun
        -->READS SQL DATA
        -->COMMENT '字符串链接';
 查看:SHOW FUNCTION STATUS like 'function_name';
       SHOW CREATE FUNCTION  function_name;
       SHOW FUNCTION STATUS like'fun';
       SHOW CRETA FUNCTION fun;
     

> ----------------------------------------------------------
> SHOW CREATE FUNCTION 用来查看函数信息包括函数内容等;
> SHOW FUNCTION STATUS 用来查看自定义函数的状态,包括所属数据库,类型,函数名称,修改时间状态的信息

调用: SELECT function_name (parameter_value,...)

在这里插入图片描述
2020年11月21日结束

love

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值