第68讲:MySQL触发器的核心概念以及常见的触发类型应用案例

文章目录

    • 1.触发器的概念
    • 2.触发器操作的语法结构
    • 3.各类触发器的典型应用案例
      • 3.1.需求描述以及实现思路
      • 3.2.创建日志表
      • 3.3.INSERT类型的触发器
      • 3.4.UPDATE类型的触发器
      • 3.5.DELETE类型的触发器

1.触发器的概念

触发器是与表中数据相关的数据库对象,当表中的数据产生inster、update、delete这类操作时,可以通过触发器在这些动作之前或者之后,去完成相应的操作,例如向表中插入一条数据,插入数据之后通过触发器完成一些操作。

在触发器中会定义很多的SQL语句集合,当满足执行触发器的动作后,会执行触发器中的SQL语句。

触发器可以协助应用程序在数据库端确保数据的完整性、日志记录、数据校验等各种操作,触发器的最典型案例就是记录表中数据的操作日志,例如当增加一条数据时,就执行触发器中的逻辑,记录本次插入的数据内容到一张日志表中,当表中数据被修改后,就通过触发器在日志表中记录数据修改前后的内容,即使有误删除的情况下,也可以通过日志表快速恢复数据,同时也可以记录用户的行为。

可以使用触发器做一个类似回收站的功能,当产生DELETE语句时,将原数据写入到另外一张表,这张表就是回收站。

在触发器中有两类别名用来引用触发器中发生变化后的记录内容:

  • OLD:记录触发器发生变化前的数据内容,也就是旧的数据内容。
    • 例如我们对update操作设置了触发器,old会记录触发器发生变化前后的数据内容,通过old就可以引用update修改之前的数据内容。
  • NEW:记录触发器发生变化后的数据内容,也就是新数据内容。
    • 例如update的触发器,通过old会引用update之前的数据内容,同理,通过new就可以引用update之后的数据内容。

常见的触发器类型:

  • INSERT类型触发器
    • 在INSERT类型的触发器中,我们可以通过NEW别名来引用新增加的数据内容。
  • UPDATE类型触发器
    • 在UPDATE类型的触发器中,我们可以通过OLD引用数据修改前的内容,通过NEW来引用数据修改后的内容。
  • DELETE类型触发器
    • 在DELEET类型的触发器中,我们可以通过OLD来引用被删除的数据内容。

MySQL只支持行级触发器。

2.触发器操作的语法结构

创建触发器

CREATE TRIGGER 触发器名称
BEFORE/AFTER INSERT/UPDATE/DELETE				#BEFORE数据变动之前 AFTER数据变动之后 INSERT/UPDATE/DELETE表示触发器类型
ON 要对那张表设置触发器 FOR EACH ROW	#行级触发器		
BEGINSQL语句
END

查看触发器

SHOW TRIGGERS

删除

DROP TRIGGER 触发器名称

3.各类触发器的典型应用案例

3.1.需求描述以及实现思路

通过触发器去监控xscjb表,针对表中数据的增删改三类操作,将变更的内容以日志的形式记录到xscjb_logs表中。

我们要针对表中数据的增删改三类都要进行日志记录,那么需要分别对这三类的操作定义一个触发器。

实现思路:

  • 首先定义一张xscjb_logs表,用于记录xscjb表的增删改变更内容。
  • 然后分别对增删改三种操作定义触发器,触发器的执行要在增删改之后再执行。
  • 最后在触发器中定义SQL语句,通过insert语句将表数据变更前后的内容写入到日志表中,数据变更前的内容可以通过old.字段的方式获取,数据变更后的内容可以通过new.字段的方式获取。

插入数据的触发器只需要通过new别名来记录新数据的内容日志即可。

更新数据的触发器需要通过old记录更新前的数据内容,也要通过new记录更新后的数据内容,都写入到日志表。

删除数据的触发器只需要通过old来记录数据删除前的内容即可。

3.2.创建日志表

在日志表中可以定义这些字段:

1)操作类型:记录该条日志是针对什么类型的操作触发的,如insert。

2)操作时间:记录数据变动的执行时间,

3)发生变动的数据在原表的主键内容:记录变动的数据在原表的主键字段的内容。

4)日志内容:记录数据变动前后的内容。

create table xscjb_logs(id int not null auto_increment,oper_type varchar(10) not null comment '操作类型',oper_time datetime not null comment '操作时间',data_id int not null comment '变动的数据在原表的主键id',oper_log varchar(500) comment '数据变动前后的内容',primary key (id)
) 

3.3.INSERT类型的触发器

先来定义一个数据插入的触发器,当表中有数据插入时,通过INSERT类型的触发器,将插入的数据记录在日志表中。

1)创建触发器

create trigger xscjb_trigger_insert
after insert on xscjb for each row
begininsert into xscjb_logs (id,oper_type,oper_time,data_id,oper_log) values (null,'insert',now(),new.xh,concat('插入的数据内容为:xh=',new.xh,',xm=',new.xm,',ywcj=',new.ywcj,',sxcj=',new.sxcj,',yycj=',new.yycj));
end;

2)触发器每条语句的含义

create trigger xscjb_trigger_insert
after insert on xscjb for each row			#after表示数据变动之后执行触发器,insert表示是插入类型的触发器,当表中数据插入完成后再执行触发器,针对xscjb的触发器
begin#整个触发器中只有一条SQL,那就是将变动的数据插入到日志表中insert into xscjb_logs 				(id,oper_type,oper_time,data_id,oper_log) 			#为日志表中每一个字段都写入内容values (null,				#id字段不用写,id字段是主键,并且自增,无需填写内容'insert',			#操作类型字段填写insert即可,表示这是INSTER触发器产生的日志now(),				#操作时间字段可以通过now函数自动填写当前的日期时间new.xh,				#data_id字段要记录数据在原表的主键字段值,数据变动之后的内容都记录在new别名中,当然也可以使用old,但是insert语句没有old别名,因此我们可以通过引用new别名+指定的字段来读取数据变动后,该字段的内容,将读取到的主键内容写入到data_id字段concat('插入的数据内容为:xh=',new.xh,',xm=',new.xm,',ywcj=',new.ywcj,',sxcj=',new.sxcj,',yycj=',new.yycj)#操作日志字段主要记录数据变动前后的内容,由于是inster类型的触发器,只记录数据变动后新增的内容,作为日志内容即可,通过concat字符串拼接函数将内容形成一段话,然后将变动的每个字段值通过new别名进行引用,就可以拿到数据变动后的新内容);	
end;

3)向xscjb表写入数据,观察日志表是否有数据产生

为了更加直观,可以写入多条数据。

insert into xscjb values (NULL,'小江','88','77','66');

当xscjb这张表有数据插入,那么日志表就会通过触发器产生对应的inster日志,在data_id字段可以看到那条数据发生了数据变动,在oper_log字段可以看到具体的数据变更动作和变更的数据内容。

image-20220617234325902

3.4.UPDATE类型的触发器

INSTER类型的触发器定义完毕了,当有数据产生时,就会将产生的数据内容和动作记录在日志表里,下面来定义UPDATE类型的触发器,当有数据发生了变化,就将数据更新的前后内容都记录在日志表中。

1)创建触发器

create trigger xscjb_trigger_update 
after update on xscjb for each row
begininsert into xscjb_logs (id,oper_type,oper_time,data_id,oper_log) values (null,'update',now(),old.xh,concat('更新前的数据内容:xh=',old.xh,',xm=',old.xm,',ywcj=',old.ywcj,',sxcj=',old.sxcj,',yycj=',old.yycj,'  更新后的数据内容:xh=',new.xh,',xm=',new.xm,',ywcj=',new.ywcj,',sxcj=',new.sxcj,',yycj=',new.yycj));
end;

2)触发器每条语句的含义

触发器和INSERT类型的触发器语法结构一样,只不过改了几个关键字,对日志的内容增加了更加详细的内容。

create trigger xscjb_trigger_update 
after update on xscjb for each row			#update类型的触发器要将第二个关键字设置为update
begininsert into xscjb_logs (id,oper_type,oper_time,data_id,oper_log) values (null,'update',						#操作类型改为updatenow(),old.xh,				#这里要记录原始数据的主键值,由于是update类型,面向的是旧数据,因此通过old别名获取数据的主键值concat('更新前的数据内容:xh=',old.xh,',xm=',old.xm,',ywcj=',old.ywcj,',sxcj=',old.sxcj,',yycj=',old.yycj,'  更新后的数据内容:xh=',new.xh,',xm=',new.xm,',ywcj=',new.ywcj,',sxcj=',new.sxcj,',yycj=',new.yycj)#update语句会通过old别名记录更新前的数据,通过new记录更后的数据,为了方便查看,我们可以在操作日志中记录update更数据前后的数据内容,更新前通过old别名引用获取指定字段的数据,更新后通过new别名引用获取指定字段的数据);
end;

3)更新xscjb表中的数据观察日志表

update xscjb set ywcj = '100' where xm = '小黑';

当xscjb表的数据发生更改时,xscjb_trigger_update触发器就会向日志表中写入一条数据,记录数据更新前后的内容。

image-20220617235643041

3.5.DELETE类型的触发器

最后我们再来定义一个DELETE类型的触发器,当表中数据删除后,在日志表中记录被删除的数据内容。

1)创建触发器

create trigger xscjb_trigger_delete
after delete on xscjb for each row
begininsert into xscjb_logs (id,oper_type,oper_time,data_id,oper_log) values (null,'delete',	now(),old.xh,concat('删除的数据内容:xh=',old.xh,',xm=',old.xm,',ywcj=',old.ywcj,',sxcj=',old.sxcj,',yycj=',old.yycj));
end;

2)触发器每条语句的含义

create trigger xscjb_trigger_delete
after delete on xscjb for each row				#delete类型的触发器要将第二个关键字设置为delete
begininsert into xscjb_logs (id,oper_type,oper_time,data_id,oper_log) values (null,'delete',					#操作类型改为deletenow(),old.xh,				#这里要记录原始数据的主键值,由于是delete类型,面向的是旧数据,因此通过old别名获取数据的主键值concat('删除的数据内容:xh=',old.xh,',xm=',old.xm,',ywcj=',old.ywcj,',sxcj=',old.sxcj,',yycj=',old.yycj));			#最后将日志内容稍加变动即可
end;

3)删除多条数据观察日志表的记录

delete from xscjb where xh > '9';

删除的条件是xh大于9的,数据删除完成后,在日志表中会记录被删除的数据。

image-20220618000638627

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/132043.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

完美解决RuntimeError: expected scalar type Long but found Float

文章目录 一、错误解释RuntimeError: expected scalar type Long but found Float二、错误分析三、解决办法总结 一、错误解释RuntimeError: expected scalar type Long but found Float RuntimeError:应为标量类型Long,但找到了Float 二、错误分析 我…

MongDB 的安装 无废话

MongDB 的安装 1 安装 MongDB https://www.mongodb.com/try/download/community-kubernetes-operator 这里我们选择 ZIP 解压到文件夹 创建 data 文件 在 data 文件夹里面创建 db 和 logs 文件夹 进入 bin 目录 输入 cmd 回车 2 启动 MongDB 输入启动命令 mongod --dbpath..\…

csapp bomb lab part4

csapp bomb lab part4 phase 5 是一个循环,不断累加,访问的地址基于0x4024b0, phase 6 之后更新 汇编 地址计算 寄存器 cl 是 x86 汇编语言中的一个 8 位寄存器,它是 ecx 寄存器的低位部分。 具体来说,x86 架构中的寄存器可…

centos7中多版本go安装

安装go的方式 官网下载tar.gz包安装 # 1.下载tar包 wget https://go.dev/dl/go1.18.1.linux-amd64.tar.gz # 2.解压tar包到指定路径 tar -xvf go1.18.1.linux-amd64.tar.gz -C /usr/local/go1.18 # 3.配置环境变量,打开 /etc/profile 文件添加以下文件每次开机时…

详解 SpringMVC 的 HttpMessageConverter

文章目录 前言参考资料内容1、[RequestBody ](/RequestBody )2、RequestEntity3、[ResponseBody ](/ResponseBody )4、SpringMVC处理json5、SpringMVC处理ajax6、RestController注解7、ResponseEntity 推荐读物 《Spring Boot微服务实战(第2版)》内容简介目录 前言 HttpMessag…

笔记本360wifi,wifi共享大师掉线,

笔记本上搭建的wifi热点,例如360wifi、wifi共享大师等,手机连接wifi后总是隔一段时间掉线。原因:网卡驱动和无线驱动有问题,需要更新或换成稳定的网卡驱动和无线驱动。 解决方案: ① 安装驱动精灵: ②点击驱动管理 ③ ④ ⑤进行阻止windo…

iOS自动化测试方案(四):保姆级搭建iOS自动化开发环境

文章目录 一、基础环境准备1.1、MacOS虚拟机 二、iPhone虚拟机三、MacOS虚拟机连接iphone真机四、扩展&&问题4.1、如果appium启动app失败,可能是appium driver没有安装xcuitest插件4.2、下载并安装Appium服务端,inspector元素定位器4.3、下载app…

贝锐向日葵亮相阿里云“云栖大会”:独创专利算法赋能全新云桌面

2023年10月31日-11月2日,一年一度的云栖大会如期举办,国产远程连接服务创领者贝锐受邀参与。活动现场,贝锐CTO张小峰进行了分享,宣布贝锐旗下国民级远程控制品牌“贝锐向日葵”与无影展开合作,同时全新的“云桌面”将于…

数据结构:AVL树讲解(C++)

AVL树 1.AVL树的概念2.平衡因子3.节点的定义4.插入操作5.旋转操作(重点)5.1左单旋5.2右单旋5.3左右双旋5.4右左双旋 6.一些简单的测试接口7.完整代码 1.AVL树的概念 普通二叉搜索树:二叉搜索树 二叉搜索树虽可以缩短查找的效率,但…

安装MySQL时出现 由于找不到 MSVCR120.dll,无法继续执行代码。重新安装程序可能会解决此问题。

--------------------------- mysqld.exe - 系统错误 --------------------------- 由于找不到 MSVCR120.dll,无法继续执行代码。重新安装程序可能会解决此问题。 --------------------------- 确定 --------------------------- 安装MySQL时出现 “This appl…

分布式服务框架设计

目录 服务框架的设计 服务框架的功能 服务框架的性能指标 服务治理需要哪些功能 服务框架的设计 尽管不同的分布式服务框架实现细节存在差异,但是核心功能差异不大,下面的架构图描绘了一个分布式服务框架的整体逻辑架构 总共分为 3 层:1…

Ansible自动化安装部署及使用

目录 前言 一、环境概况 修改主机名(可选项) 二、安装部署 1.安装epel扩展源 2.安装Ansible 3.修改Ansible的hosts文件 4.生成密钥 三、Ansible模块使用介绍 Command模块 Shell模块 User模块 Copy模块 File模块 Hostname模块 Yum模块 Ser…

Ubuntu重启后进入initramfs导致无法开机解决方案

今天,我的电脑意外关机,重新开机后打开了虚拟机。该虚拟机使用的是 Ubuntu 22.04 系统。但重启后,系统一直显示(initramfs):,导致无法正常启动。最后,在网上查找了一些解决方案,成功解决了这个开机问题。在…

圣杯布局/双飞翼布局/flex/grid等,实现CSS三栏自适应布局的几种方法

简介 三栏布局是网页设计中常用的布局,即网页中的内容被分为三块:左侧/中间/右侧。其中两侧部分宽度固定,中间部分宽度自适应的根据浏览器宽度撑满剩余空间。而三栏布局也有很多变形,比如两栏或者N栏布局,上中下三栏布…

Linux shell编程学习笔记21:用select in循环语句打造菜单

一、select in循环语句的功能 Linux shell脚本编程提供了select in语句,这是 Shell 独有的一种循环语句,非常适合终端(Terminal)这样的交互场景,它可以根据用户的设置显示出带编号的菜单,用户通过输入不同…

爱德华的台灯真的好用?爱德华、书客、好视力护眼台灯对比测评

如今孩子近视的比例越来越大,而且时间越来越提前,一些上小学的孩子开始近视佩戴眼镜。其实造成近视的原因不外乎作业坐姿不标准,学业时间太长缺少户外的运动,也包括可能灯光光源的问题造成对于视力的影响。如果希望孩子有一个较好…

3.26每日一题(线性非齐次的特解如何设)

1、非齐次方程有e的2x次幂:特解也有e的2x次幂 2、e的2x次幂前面有特殊的一元方程:特解要设为一般的特征方程(axb) 3、求线性齐次特征方程的特征根; 4、判断e的 rx 次幂中的 r 和特征根有没有重合的个数:…

【每日一题】数组中两个数的最大异或值

文章目录 Tag题目来源题目解读解题思路方法一:哈希集合 其他语言python3 写在最后 Tag 【哈希集合】【位运算-异或和】【数组】【2023-11-04】 题目来源 421. 数组中两个数的最大异或值 题目解读 找出数组中两个数的最大异或结果。 解题思路 一看数据量达到了 …

Ubuntu20.04搭建RISC-V和qemu环境

1. 前言 risc-v是一个非常有潜力的指令集框架,最近对其产生了浓厚的兴趣,由于之前对于这方面的知识储备很少,在加上网上的教程都是点到为止,所以安装过程异常曲折。好在最后一步一步积累摸索,终于利用源码安装完成。看…

【中国知名企业高管团队】系列59:TCL

今天华研荟为大家介绍TCL公司的情况和创始人李东生先生的故事。 一、关于TCL TCL创立于1981年,前身为中国首批13家合资企业之一:TTK家庭电器(惠州)有限公司,该公司为中港合资企业,最初从事卡式录音磁带的生产制造,19…