Mysql自定义函数

今天写一个简单点的自定义函数muniu:
实现两个数的加减muniu(a,b,op);

drop function if exists muniu;
delimiter $$
create function muniu(a int(11),b int(11), op varchar(50)) returns int
begin 
	declare p varchar(80);
	select op into p;
	if(trim(p)="+")
		then return a+b;
	elseif trim(p) = "-"
		then return a-b;
	end if;
end$$
delimiter ; 

将如上的代码放入mysql中运行,如下所示,实现了自定义的两个数的加法与减法运算

mysql> drop function if exists muniu;
Query OK, 0 rows affected (0.00 sec)

mysql> delimiter $$
mysql> create function muniu(a int(11),b int(11), op varchar(50)) returns int
    -> begin
    ->  declare p varchar(80);
    ->  select op into p;
    ->  if(trim(p)="+")
    ->          then return a+b;
    ->  ***elseif trim = "-"#这里写错了***
    ->          then return a-b;
    ->  end if;
    -> end$$
Query OK, 0 rows affected (0.00 sec)

mysql> delimiter ;
mysql>
mysql> select muniu(3,5,"  +  ");
+--------------------+
| muniu(3,5,"  +  ") |
+--------------------+
|                  8 |
+--------------------+
1 row in set (0.00 sec)

mysql> select muniu(8,2,"  -  ");
ERROR 1054 (42S22): Unknown column 'trim' in 'field list'
mysql>
mysql>
mysql>
mysql>
mysql> drop function if exists muniu;
Query OK, 0 rows affected (0.00 sec)

mysql> delimiter $$####修改之后重新运行一遍
mysql> create function muniu(a int(11),b int(11), op varchar(50)) returns int
    -> begin
    ->  declare p varchar(80);
    ->  select op into p;
    ->  if(trim(p)="+")
    ->          then return a+b;
    ->  elseif trim(p) = "-"
    ->          then return a-b;
    ->  end if;
    -> end$$
Query OK, 0 rows affected (0.00 sec)

mysql> delimiter ;
mysql>
mysql>
mysql> select muniu(3,5,"  +");
+------------------+
| muniu(3,5,"  +") |
+------------------+
|                8 |
+------------------+
1 row in set (0.00 sec)

mysql> select muniu(8,2,"-  ");
+------------------+
| muniu(8,2,"-  ") |
+------------------+
|                6 |
+------------------+
1 row in set (0.00 sec)

自定义函数的意义:
官方函数是有限的,特殊的需求需要自定义函数来实现

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值