mysql自定义函数详解_mysql自定义函数详解

mysql自定义函数详解_mysql自定义函数详解需求:对于数据库中的记录,如果有两条连续的数据的value字段的值相同,则发邮件通知相关人员。需求分析:告警系统里面的告警检查是通过SQL来进行的,一般的SQL实现不了此功能,因此,这里可以通过函数的方式来实现。具体实现如下:1、数据表准备:tb_config_record。新建数据表脚本如下:createtabletb_config_record(idint,statusvarch…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

需求:对于数据库中的记录,如果有两条连续的数据的value字段的值相同,则发邮件通知相关人员。

需求分析:告警系统里面的告警检查是通过SQL来进行的,一般的SQL实现不了此功能,因此,这里可以通过函数的方式来实现。

具体实现如下:

1、数据表准备:tb_config_record。新建数据表脚本如下:

create table tb_config_record (id int ,status  varchar(20), value  varchar(20), updated_at datetime, updated_by varchar(20), created_at datetime, created_by varchar(20)) ;

2、数据准备。脚本如下:

insert into tb_config_record (id , status ,value ,updated_at ,updated_by , created_at , created_by) values(1,’SUCCESS’,’0′,now(),’SYS’,now(),’SYS’);

insert into tb_config_record (id , status ,value ,updated_at ,updated_by , created_at , created_by) values(2,’SUCCESS’,’1′,now(),’SYS’,now(),’SYS’);

insert into tb_config_record (id , status ,value ,updated_at ,updated_by , created_at , created_by) values(3,’SUCCESS’,’2′,now(),’SYS’,now(),’SYS’);

insert into tb_config_record (id , status ,value ,updated_at ,updated_by , created_at , created_by) values(4,’SUCCESS’,’3′,now(),’SYS’,now(),’SYS’);

insert into tb_config_record (id , status ,value ,updated_at ,updated_by , created_at , created_by) values(5,’SUCCESS’,’4′,now(),’SYS’,now(),’SYS’);

insert into tb_config_record (id , status ,value ,updated_at ,updated_by , created_at , created_by) values(6,’SUCCESS’,’6′,now(),’SYS’,now(),’SYS’);

insert into tb_config_record (id , status ,value ,updated_at ,updated_by , created_at , created_by) values(7,’SUCCESS’,’6′,now(),’SYS’,now(),’SYS’);

3、函数编写。

delimiter //

create function has_serial_status() returns integer

begin

declare val varchar(20) ;

declare tmp varchar(20)  default null ;

declare result integer default 0 ;

declare  value_serials_cursor  cursor for select value from tb_config_record where status = ‘SUCCESS’ order by id asc ;

declare exit handler for not found  return result;

open value_serials_cursor ;

loop_serials : loop

fetch value_serials_cursor into val ;

if val = tmp then

set result = 1 ;

leave loop_serials ;

else

set tmp = val ;

end if;

end loop ;

close value_serials_cursor ;

return result ;

end //

delimiter ;

4、执行结果

40417215954895d792098d316961e212.png

删除id=7的记录后,重新执行函数

cd1598a36649bbabf2316b429c6b4d64.png

总结:

函数按照预期的方式运行,得到正确的结果。具体操作过程中遇见以下困难:

1、函数编写时,每行都要顶格写,不然就会出现如下错误

6f4a15cd1407bad6dccf917a623287e8.png

运行错误:

b7001ea5c6d7a63999a92f209db0b7a9.png

2、需要在函数语句中添加语句:declare exit handler for not found  return result;

否则出现如下错误:

52b29197313bb6bb53ac4980c59bd41d.png

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/196090.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • NPMDev0.0.1测试版发布,为TP开发者量身定制的PHP开发环境

    NPMDev0.0.1测试版发布,为TP开发者量身定制的PHP开发环境

    2021年7月31日
    70
  • MATLAB强化学习入门——三、深度Q学习与神经网络工具箱

    MATLAB强化学习入门——三、深度Q学习与神经网络工具箱零、为什么需要深度Q学习上一期的文章《网格迷宫、Q-learning算法、Sarsa算法》的末尾,我们提到了Q学习固有的缺陷:由于智能体(agent)依赖以状态-动作对为自变量的Q函数表(QFunctionTable)来形成对当前状态的估计,并以此为依据利用策略π选择动作。Q函数表就必须包含智能体在环境中所可能出现的所有动作-状态对及其对应Q值。显然,当一个多步决策问题变得足够复杂甚至变为连…

    2022年10月3日
    0
  • 利用python制作电子签名

    利用python制作电子签名

    2021年11月19日
    85
  • 【并发缺陷】data race数据竞争、atomicity violation原子违背、order violation顺序违背

    【并发缺陷】data race数据竞争、atomicity violation原子违背、order violation顺序违背三类均是跟共享变量的内存访问有关的缺陷。对于并发缺陷的分类目前国内许多是分死锁、数据竞争、原子违背、顺序违背。或者在并发缺陷中又细分concurrencyvulnerability:死锁和数据竞争。感觉各个作者有自己的分类方法????以下引用的中文解释来自<并发缺陷暴露、检测与规避研究综述>哈工大的苏小红老师实验室发表在2015年计算机学报上目前找到外文文献分为7类。其他四类…

    2022年10月29日
    0
  • 开发网络游戏的成本(经营成本与总成本区别)

    开发一个网络游戏以开发团队30人,开发周期18个月,人均月成本1万元计算.(这个是概数),约为540万.计算技术购买,测试服务器费用等等等等其他一切费用,普通国产网络游戏开发成本应该在600-1000万之间.运营成本.假设准备做到在线5万人,以平均10台服务器/组,5000人/组承载计算,约需10组,100台服务器.算上网站服务器,备用服务器等等,120台服务器投入是比较保守的估计.以单台平…

    2022年4月15日
    293
  • 画二元函数即三维图像的函数及matlab代码

    画二元函数即三维图像的函数及matlab代码画二元函数,即两个变量可以得到三维图像,下面通过一个例子进行讲解。首先利用meshgrid函数产生平面区域内的网格坐标矩阵。x=[1,2,3,4,5]y=[2,4,6];[X,Y]=meshgrid(x,y);执行完以后X、Y均为矩阵,其中矩阵X的每一行都是向量x,行数等于向量y的元素的个数,矩阵Y的每一列都是向量y,列数等于向量x的元素的个数,具体则为:接…

    2022年9月6日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号