MySQL自定义函数及触发器


Posted in MySQL onAugust 05, 2022

1. 存储函数(自定义函数)

  • 自定义函数是一种对MySQL扩展的途径,其用法与内置的函数相同。
  • 定义函数的两个必要条件:参数、返回值。函数可以返回任意类型的值,同样可以接收这些类型的参数。

关于函数体:

  • 函数体是由合法的SQL语句构成。
  • 函数体可以是简单的SELECT或INSERT语句。
  • 函数体如果为符合结构则使用BEGIN....AND语句包裹。
  • 复合结构可以包含声明、循环、控制结构等等。

重点:自定义的函数不能重名,类似于定义了一个全局变量,变量名不能一致。

1.1 定义存储函数

语法格式:

create function 函数名(参数列表)
returns type(返回值类型)
begin
    --SQL语句
end;

需求:定义一个存储过程的函数,获取满足条件的总记录条数

实现:

delimiter $
create function fun(countryId int)
returns int 
begin
    # 定义一个存储总数据条数的变量
    declare cum int default 0;
    # 查询等于传递参数的全部的数据数,然后将其赋值给定义的变量
    select count(*) into cum from city where country_id = countryId;
    # 返回结果值。存储函数必须有返回值
    return cum;
end $

delimiter ;

1.2 调用存储函数

语法格式:

select 函数名(参数列表);

注意:调用存储过程的时候使用的是call关键字,但是在调用存储函数的时候直接使用select即可,就和调用MySQL一个普通的聚合函数的方式一样即可。

select fun(1);
# 这里和存储过程一样,调用的时候需要加小括号和参数,但是在删除的时候指定函数名即可

1.3 删除存储函数

语法格式

drop [if exists] function fun;

2. 触发器

2.1 触发器介绍

  • 触发器是与表有关的数据库对象,指在 insert/update/delete 之前或之后,触发并执行触发器中定义的SQL集合。触发器的这种特性可以协助应用在数据库端确保数据的完整性、日志记录以及数据校验等操作。
  • 只有增加、删除、修改的时候才可以使用触发器,查询的时候不可以使用触发器。
  • 使用别名OLD和NEW来引用触发器中发生变化的记录内容,这与其他的数据库是相似对的。MySQL触发器还只支持行级触发,不支持语句级触发。oracle支持行级和语句级触发器都支持。
  • OLD、NEW这两个变量又叫做行记录变量。可以通过这个两个变量来获取即将要操作的数据表中的数据。

MySQL自定义函数及触发器

2.2 创建触发器

语法格式:

create trigger(触发器) trigger_name(触发器名称)
before/after insert/update/delete
on tab_name(表名)
[for each row](行级触发器)
begin
    trigger_stmt;(触发器的逻辑)
end;

需求:通过触发器记录 emp 表的数据变更日志 emp_logs ,其中包含增加、修改、删除

实现:

分析:一个触发器只能操作一种数据的操作类型,不可以同时完成增加、修改、删除的操作。所以此时需要定义多个触发器来完成这个日志记录的任务。

因为 MySQL中是行级操作的触发器,所以 new 以及 old 中存储的都是一整行数据。

创建执行 insert 的触发器:

MySQL自定义函数及触发器

  • 使用 new 关键字可以获取到操作的数据,在insert模式下,new变量中存储的就是即将插入的数据
  • 使用的是 after ,在执行完表 emp 的新增之后执行这个触发器记录日志。
  • 这个触发器什么时候执行与两点有关:
    • 必须操作的是 emp 这个表,也就是on后面声明的这个表。
    • 必须执行的 insert 操作。

创建执行 update 的触发器:

MySQL自定义函数及触发器

此时 old 变量中存储的是被修改前的数据,new 变量中存储的是修改之后的数据

创建执行 delete 的触发器:

MySQL自定义函数及触发器

此时的 old 变量中存储的即将删除的数据

测试:测试都必须是操作的 emp 表,这样才会触发上边定义的触发器。

MySQL自定义函数及触发器

2.3 删除触发器

语法结构:

drop trigger [schema_name.](数据库名)trigger_name(触发器名);

如果没有指定 schema_name(数据库名),默认为当前数据库。

2.4 查看触发器

可以通过执行 show triggers 命令查看触发器的状态、语法等信息。

语法结构:

show triggers;

到此这篇关于MySQL自定义函数以及触发器的文章就介绍到这了,更多相关MySQL 触发器内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

MySQL 相关文章推荐
mysql在项目中怎么选事务隔离级别
May 25 MySQL
浅谈mysql返回Boolean类型的几种情况
Jun 04 MySQL
如何搭建 MySQL 高可用高性能集群
Jun 21 MySQL
MySQL系列之十三 MySQL的复制
Jul 02 MySQL
MySql子查询IN的执行和优化的实现
Aug 02 MySQL
MySQL实例精讲单行函数以及字符数学日期流程控制
Oct 15 MySQL
MySQL数据库⾼可⽤HA实现小结
Jan 22 MySQL
分享MySQL常用 内核 Debug 几种常见方法
Mar 17 MySQL
MySQL时区造成时差问题
Apr 13 MySQL
MySQ InnoDB和MyISAM存储引擎介绍
Apr 26 MySQL
MySQL数据库中的锁、解锁以及删除事务
May 06 MySQL
MySql统计函数COUNT的具体使用详解
Aug 14 MySQL
MySQL性能指标TPS+QPS+IOPS压测
Aug 05 #MySQL
Mysql中mvcc各场景理解应用
Aug 05 #MySQL
数据设计之权限的实现
一文解答什么是MySQL的回表
Aug 05 #MySQL
MySQL一劳永逸永久支持输入中文的方法实例
Aug 05 #MySQL
SQLServer常见数学函数梳理总结
Aug 05 #MySQL
MySQL生成千万测试数据以及遇到的问题
Aug 05 #MySQL
You might like
php CI框架插入一条或多条sql记录示例
2014/07/29 PHP
PHP无限极分类函数的实现方法详解
2017/04/15 PHP
thinkPHP5.0框架验证码调用及点击图片刷新简单实现方法
2018/09/07 PHP
Javascript 错误处理的几种方法
2009/06/13 Javascript
50款非常棒的 jQuery 插件分享
2012/03/29 Javascript
利用NodeJS和PhantomJS抓取网站页面信息以及网站截图
2013/11/18 NodeJs
js仿土豆网带缩略图的焦点图片切换效果实现方法
2015/02/23 Javascript
Angular中的Promise对象($q介绍)
2015/03/03 Javascript
JavaScript学习笔记之数组随机排序
2016/03/23 Javascript
jQuery Ajax使用FormData对象上传文件的方法
2016/09/07 Javascript
vue.js获取数据库数据实例代码
2017/05/26 Javascript
bootstrap-table.js扩展分页工具栏(增加跳转到xx页)功能
2017/12/28 Javascript
JS 使用 window对象的print方法实现分页打印功能
2018/05/16 Javascript
bootstrapTable+ajax加载数据 refresh更新数据
2018/08/31 Javascript
基于axios 解决跨域cookie丢失的问题
2018/09/26 Javascript
Vue通过WebSocket建立长连接的实现代码
2019/11/05 Javascript
在vue项目实现一个ctrl+f的搜索功能
2020/02/28 Javascript
探究一道价值25k的蚂蚁金服异步串行面试题
2020/08/21 Javascript
[02:40]2014DOTA2 国际邀请赛中国区预选赛 四大豪门抵达华西村
2014/05/23 DOTA
[03:46]DAC趣味视频-中文考试.mp4
2017/04/02 DOTA
python3实现TCP协议的简单服务器和客户端案例(分享)
2017/06/14 Python
Pycharm编辑器技巧之自动导入模块详解
2017/07/18 Python
Python中支持向量机SVM的使用方法详解
2017/12/26 Python
python将回车作为输入内容的实例
2018/06/23 Python
Python分支语句与循环语句应用实例分析
2019/05/07 Python
python MD5加密的示例
2020/10/19 Python
HTML中使用SVG与SVG预定义形状元素介绍
2013/06/28 HTML / CSS
Cotton On南非:澳洲时尚平价品牌
2018/06/28 全球购物
Chupi官网:在爱尔兰手工制作的订婚、结婚戒指和精美珠宝
2020/09/28 全球购物
为什么要使用servlet
2016/01/17 面试题
公立医院改革实施方案
2014/03/14 职场文书
承诺书怎么写
2014/03/26 职场文书
警校毕业生自我评价
2014/04/06 职场文书
新春寄语大全
2014/04/09 职场文书
幼儿教师辞职信
2015/02/27 职场文书
gtx1650怎么样 gtx1650显卡相当于什么级别
2022/04/08 数码科技