MySQL之自定义函数

       MySQL中已经有很多函数,如时间函数等,但是有时这些函数不能满足自己的设计需求,此时需要自定义函数,用户自定义函数(User-defined functuin,UDF)是对MySQL的扩展,其用法和内置函数相同

函数需要具备:参数 返回值

对于函数体中的部分可以是:

1、函数体由合法的SQL语句组成

2、函数体可以是简单的select或者insert语句

3、函数体若为复合结构则使用begin...end语句

4、复合结构可以包含声明、循环、控制结构

1、无参数

       知道通过now()函数可以显示日期和时间,如果想把这个时间表达成:“年月日时分秒” 的形式怎么办呢?通过使用格式化函数DATE_FORMAT()

mysql> select DATE_FORMAT(NOW(),'%Y年%m月%d日 %H点:%i分:%s秒');

由于该过程书写较为麻烦,如果经常使用很不方便,因此将其“制作”成函数

mysql> create FUNCTION f1() returns varchar(30)
    -> RETURN DATE_FORMAT(NOW(),'%Y年:%m月:%d日 %H点:%i分:%s秒');

由于在定义f1()的时候没有参数,因此调用时就可以直接调用

mysql> select f1();

2、带有参数

带有一个以上的参数时,这里求解两个数的平均数

mysql> create FUNCTION f2(num1 smallint unsigned,num2 smallint unsigned)  #函数名
    -> RETURNS FLOAT(10,2) UNSIGNED       #返回值的类型
    -> RETURN (num1+num2)/2;              #返回值

3、创建具有复合结构的函数

首先创建一个数据表test

root@localhost test>create table test(id tinyint(3) unsigned primary key auto_increment,
    -> username varchar(30) not null
    -> );

现在想往数据表中插入记录,返回值是新插入的记录的id号

root@localhost test>insert into test values(default,'Lj.K');
由于分号是命令的结束,因此这里需要修改默认的分隔符,否则在输入分号之后无法返回新插入记录的id,因此使用命令 
DELIMITER 分隔符

这样所有的命令均需要以分隔符来结束


比这将分隔符修改为//,则所有命令均需要以 // 为结束

root@localhost test>create FUNCTION adduser(username varchar(20))  #创建添加参数名为username的函数adduser
    -> RETURNS INT UNSIGNED
    -> BEGIN
    -> INSERT test(username) VALUES(username);
    -> RETURN LAST_INSERT_ID();
    -> END
    -> //

这里因为有两条语句 insert test(username) values(username)和return last_insert_id()两条语句要执行,因此需要使用BEGIN...END语句,从而构成聚合体

root@localhost test>select  adduser('Rose');
    -> //

root@localhost test>DELIMITER ;
root@localhost test>select  adduser('Tom');

通过drop function命令进行删除

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL自定义函数是一种用户扩展功能,可以用来实现特定的逻辑和计算。通过自定义函数,我们可以在MySQL中定义并使用自己的函数,这些函数可以返回任意类型的值,并且可以接受任意类型的参数。与内置函数类似,自定义函数可以在查询中使用,并且可以在不同的表达式和语句中调用。 然而,在创建自定义函数时可能会遇到错误。其中一种可能的错误是报错信息"DROP FUNCTION [ IF EXISTS ] <自定义函数名> 5.在mysql中创建自定义函数报错"。如果你遇到了这个错误,可以尝试以下解决方法: 1. 检查自定义函数的语法是否正确。确保函数定义中没有语法错误,例如括号不匹配、缺少关键词等。 2. 检查自定义函数的权限。确保当前用户拥有创建函数的权限。如果没有权限,可以联系数据库管理员授权或使用具有相应权限的用户账户。 3. 检查自定义函数参数类型和返回值类型。确保函数定义中指定的参数类型和返回值类型与实际使用时的数据类型一致。 4. 检查自定义函数的属性。确保函数定义中没有使用DETERMINISTIC, NO SQL, or READS SQL DATA等属性,这些属性可能会导致创建函数失败。 5. 检查自定义函数的依赖关系。确保函数定义不依赖于不存在或不可用的对象,例如表、列或其他函数。 通过以上方法,你应该能够解决在MySQL中创建自定义函数时遇到的问题。如果问题仍然存在,请提供更详细的错误信息以便我们提供更准确的解决方法。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值