mysql函数编写格式_【数据库】Navicat编写MySQL自定义函数详解-Go语言中文社区

小白最近迷上了MySQL,由于工作中大部分用HIVE,很少用到MySQL,但是后来发现MySQL可以处理递归等可循环的功能,所以,就安装了一个本地的MySQL进行学习,以下是小白对自定义函数的尝试。

首先来说一下,自定义函数的优点:调用函数可以简化代码,减少工作量,减少数据在数据库和应用服务器上的传输,提高数据处理的效率。

自定义函数语法:

#创建一个函数

CREATE FUNCTION functiona(v_id INT)

RETURNS VARCHAR(50)

BEGIN

#定义变量

DECLARE aaa VARCHAR(50);

#给定义的变量赋值

SELECT bbb INTO aaa FROM table

WHERE bbb_userId = aaa_id;

#返回函数处理结果

RETURN aaa;

END;

各位,一定要与你安装的navicat中保持格式一致,不要盲目看网上的例子,小白真的深受折磨,在网上看了各种案例,大部分以一下这种形式编写,但是一运行就报错,踩过的坑如下:

DELIMITER $$

CREATE DEFINER = CURRENT_USER FUNCTION `NewProc`()

RETURNS integer

BEGIN

#Routine body goes here...

RETURN 0;

END $$

DELIMITER;

网上都说 DELIMITER $$ 函数创建定界符,BUT,看一下报错:

b3428adf51639ed6ce6b53e07123ec1d.png

小白睁大眼,仔细看,并没有任何错哇,什么鬼,以下是各种百度的过程......,最终,突然意识到,是不是应该以Navicat中给定的方式来,小白稍作修改,以上面的格式修改后,完美,执行成功了~

删除函数:

DROP FUNCTION [IF EXISTS] fn_name;

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值