22. Mysql 触发器

文章目录

    • 概念
    • 常见操作
      • 查看触发器
      • 创建触发器
      • 删除触发器
    • 精选示例
      • 数据完整性约束
      • 数据同步
      • 日志记录
    • 总结
    • 参考资料

概念

触发器(Trigger)是 Mysql 数据库中的一种特殊的存储过程,它会在数据库中的指定表上自动执行某些操作。当满足触发器定义的条件时,触发器会被触发并执行相应的操作。触发器可以用于实现数据的自动更新、数据的完整性约束等功能。

应用场景:

  • 数据完整性约束:通过触发器可以实现对表中数据的完整性约束,例如,可以在插入或更新数据时自动检查数据的合法性。
  • 数据同步:可以在一个表上的操作触发时,自动将数据同步到其他相关的表中。
  • 日志记录:可以在对表进行插入、更新或删除操作时,自动记录操作日志。
  • 数据备份:可以在对表进行插入、更新或删除操作时,自动将数据备份到其他表或文件中。

常见操作

查看触发器

使用 show 或者 select 语句查看当前数据库中所有的触发器。

show triggers;
select * from information_schema.triggers;;

创建触发器

使用 create trigger 语句来创建一个触发器,语法如下:

create[definer = user]trigger [if not exists] trigger_nametrigger_time trigger_eventon tbl_name for each row[trigger_order]trigger_bodytrigger_time: { before | after }trigger_event: { insert | update | delete }trigger_order: { follows | precedes } other_trigger_name
  • trigger_name:触发器的名称。
  • trigger_time:指定触发器的执行时间,可以是 before 或 after。
  • trigger_event:指定触发器的事件,可以是 insert、update 或 delete。
  • table_name:指定触发触发器的表名。
  • for each row:固定语法,表示触发器的每一行数据都会被触发。
  • trigger_order:可选,指定触发器顺序,可以是 follows(之后) 或 precedes(之前)激活。
  • trigger_body:触发器的具体执行逻辑,如果包含多条语句,可以使用 begin … end 复合结构。

删除触发器

使用 drop trigger 语句删除该触发器。

drop trigger [if exists] [schema_name.]trigger_name;

其中,schema_name 是数据库的名称,可选项,trigger_name是要删除的触发器的名称。

精选示例

数据完整性约束

准备工作:新建一个学生表和成绩表,创建一个触发器,用于在插入成绩数据时自动检查成绩是否合法。

create table if not exists students (id int primary key,name varchar(100),age int,gender varchar(10)
);
create table if not exists scores (id int primary key,student_id int,subject varchar(100),score int,foreign key (student_id) references students(id)
);
# 创建触发器
create trigger check_score
before insert on scores
for each row
beginif new.score < 0 or new.score > 100 thensignal sqlstate '45000' set message_text = 'invalid score';end if;
end;

触发器逻辑是插入成绩数据之前检查成绩是否合法,如果成绩小于0或大于100,则触发器会抛出一个异常。

数据同步

准备工作:新建订单表和库存表,创建一个触发器,当发生订单销售记录时,更新库存记录。

create table if not exists orders (id int primary key,product_id int,quantity int
);
create table if not exists inventory (id int primary key,product_id int,quantity int
);
# 创建触发器
create trigger update_inventory
after insert on orders
for each row
beginupdate inventory set quantity = quantity - new.quantity where product_id = new.product_id;
end;

触发器会自动在插入订单数据之后自动更新库存表中的库存数量,实施数据同步更新操作。

日志记录

准备工作:假设有文章表和文章日志表,创建一个触发器,用于在更新文章数据时自动记录更新日志。

create table articles (id int primary key,title varchar(100),content text
);
create trigger log_update
after update on articles
for each row
begininsert into article_logs (article_id, action, updated_at) values (old.id, 'update', now());
end;

这个触发器会在更新文章数据之后自动将更新日志插入到文章日志表中。

总结

触发器也可以提高数据库的自动化程度,减少手动操作的工作量。也可以帮助我们记录操作日志,具体记录什么时间进行了什么操作。这可以帮助我们更好地还原操作时的具体场景,更好地定位到问题原因所在。

参考资料

  • MySQL官方文档:https://dev.mysql.com/doc/refman/8.0/en/create-trigger.html
  • MySQL Tutorial 官方文档:https://www.mysqltutorial.org/mysql-trigger/

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

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

相关文章

Python编程+copilot+代码补全+提高效率

Python编程copilot代码补全提高效率 copilot是由Github和OpenAI合作开发的一款AI编程工具&#xff0c;它可以根据自然语言或部分代码&#xff0c;自动给出合适的代码补全建议。copilot支持多种编程语言&#xff0c;包括Python&#xff0c;也可以在Pycharm等主流IDE中使用。本资…

正则表达式速查手册

正则表达式 1、正则表达式简介2、常用正则表达式速查手册 1、正则表达式简介 正则表达式是一种强大的文本匹配工具&#xff0c;可以用于在文本中查找特定的模式 正则表达式由不同类型的字符组成&#xff0c;包括普通字符、元字符、分隔符和转义字符等。其中&#xff1a; 普通字…

超niu的正则

有一个几百行的建表语句&#xff0c;给到咱的时候各种乱&#xff0c;需要整理一下 a1 as num1 string comment , a2 as num2 string comment , ...... 在notpad里需要把上述sql修改成 num1 string comment , num2 string comment 搞了一会&#xff0c;用下面这个正则就可以…

服务器超线程的好处

服务器超线程的好处 1、提高性能&#xff1a;超线程通过提高整体系统吞吐量显着提高服务器性能。通过允许多个线程在单个物理内核上同时执行&#xff0c;超线程减少了空闲时间并最大限度地利用了可用资源。这会加快任务执行速度并缩短应用程序的响应时间&#xff0c;尤其是在多…

SpringIOC之support模块FileSystemXmlApplicationContext

博主介绍&#xff1a;✌全网粉丝5W&#xff0c;全栈开发工程师&#xff0c;从事多年软件开发&#xff0c;在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战&#xff0c;博主也曾写过优秀论文&#xff0c;查重率极低&#xff0c;在这方面有丰富的经验…

LINE网页版使用方法(内含LINE网页版特点总结)

如果想要在电脑上使用LINE&#xff0c;但是又觉得下载客户端很累赘的话&#xff0c;LINE网页版是你最好的选择。但是LINE网页版相对于其他平台来说使用方式比较少。所以今天就来讲讲&#xff0c;我们有什么方式可以在电脑中使用LINE。 LINE网页版使用方法 1.需要使用Chrome浏览…

数据的相似度计算

相似度系数又称为相关系数&#xff0c;常用于考察两个变量x、y之间的相关程度。 若为0&#xff0c;则x和y无相关性若为正&#xff0c;则x和y呈正相关&#xff0c;相关系数在0~1之间若为负&#xff0c;则x和y呈负相关&#xff0c;相关系数在-1~0之间相似度系数的绝对值越大&…

【hyperledger-fabric】部署Java应用远程访问智能合约

简介 首先是根据b站的视频 hyperledger-fabric【3】在 java 应用中访问合约 以及hyperledger-fabric【5】Java应用和私有数据&#xff0c;本文章主要讲述的是视频中我遇到的问题&#xff0c;以及相关知识点的总结。 遇到的问题 问题1&#xff1a;git clone下载下来的代码发现…

K8S学习指南(67)-脚手架工具KubeBuilder

文章目录 引言KubeBuilder 的历史发展KubeBuilder 的设计理念1. 约定优于配置2. CRD 和控制器的生成3. 可插拔的架构4. 集成了测试框架 KubeBuilder 的使用1. 安装 KubeBuilder2. 创建一个新的 KubeBuilder 项目3. 创建一个新的 API 对象4. 实现控制器逻辑5. 生成 CRD 和控制器…

esp32-s3 max98357

esp32一直正常使用&#xff08;1.0.6的esp库&#xff09;&#xff0c;最近买了esp32s3就报错如下&#xff08;2.0.5的库&#xff09;&#xff1a; E (363) I2S: i2s_calculate_common_clock(1149): sample rate is too large E (364) I2S: i2s_calculate_clock(1198): Common…

《异侠传S1赛季侠义九州》公测版本三端互通PC客户端与IOS下载地址!!!

尊敬的各位异侠玩家们&#xff1a; 我们怀着无比激动的心情&#xff0c;充满感激地向大家宣布&#xff1a;今天上午10&#xff1a;00我们即将迎来《异侠传S1赛季&#xff1a;侠义九州》的首发公测&#xff01;在这个特殊的时刻&#xff0c;我们想将我们最诚挚的感谢献给每一位…

STM32 CubeMX LwIP + freertOS 移植

开发板: 官方 STM32F746 MCU型号&#xff1a;STM32F746NGH 网卡型号&#xff1a;LAN8742A 原理图如下 先用裸机测试LAN8742A的网卡驱动 使用CubeMX创建工程 系统时钟和时基定时器如下 无系统LWIP协议栈设置&#xff0c;静态IP地址&#xff0c;关闭DHCP 生产代码&#xff…

Java版企业电子招投标系统源代码,支持二次开发,采用Spring cloud技术

在数字化时代&#xff0c;采购管理也正经历着前所未有的变革。全过程数字化采购管理成为了企业追求高效、透明和规范的关键。该系统通过Spring Cloud、Spring Boot2、Mybatis等先进技术&#xff0c;打造了从供应商管理到采购招投标、采购合同、采购执行的全过程数字化管理。通过…

网络面试题

1. 请简要介绍一下TCP/IP协议栈的层次结构。 TCP/IP协议栈是一系列网络协议的集合&#xff0c;构成了网络通信的核心骨架。这个协议采用四层结构&#xff0c;分别是链路层、网络层、传输层和应用层。 链路层是TCP/IP协议栈中的最底层&#xff0c;负责在物理媒介上发送和接收数…

iOS UITextField复制、粘贴框显示为英文如何解决

问题描述&#xff1a; 使用UITextField&#xff0c;欲粘贴文本&#xff0c;长按或者双击展示的提示框显示为英文 解决方案&#xff1a; 在Xcode配置文件info,plist文件中&#xff0c;新增Localizas属性&#xff0c;填入Chinese 结果如下&#xff1a; 提示框成功展示为中文

antv/x6_2.0学习使用(六、事件系统)

一、视图交互事件 通过鼠标、键盘或者各种可交互的组件与应用产生交互时触发的事件&#xff0c;如单击节点 ‘node:click’ 等。 1、鼠标事件 事件cell 节点/边node 节点edge 边blank 画布空白区域单击cell:clicknode:clickedge:clickblank:click双击cell:dblclicknode:dblcli…

量子计算:未来科技的革新引擎与广泛应用前景

在当今科技领域&#xff0c;量子计算机作为颠覆性的技术力量正在崭露头角。它超越了传统二进制逻辑门的经典计算框架&#xff0c;利用量子比特&#xff08;qubits&#xff09;及其叠加态和纠缠现象实现前所未有的信息处理能力。随着全球科研团队对量子计算领域的持续深耕&#…

【镜像压缩】linux 上 SD/TF 卡镜像文件压缩到实际大小的简单方法(树莓派、nvidia jetson)

文章目录 1. 备份 SD/TF 卡为镜像文件2. 压缩镜像文件2.1. 多分区镜像文件的压缩&#xff08;树莓派、普通 linux 系统等&#xff09;2.2. 单分区镜像文件的压缩&#xff08;Nvidia Jetson Nano 等&#xff09; 3. 还原镜像文件到 SD/TF 卡参考链接 1. 备份 SD/TF 卡为镜像文件…

运用Jmeter进行登录测试

开始了解Jmeter,写篇关于Jmeter的博客做备忘,这里以苏宁易购网站的登录请求为例实战来说明测试计划元件,创建一个 Web 测试计划。 今天简单介绍Jemeter的入门,Jmeter 的安装这边就跳过,直接讲述如何使用JMETER,如何运用Jmeter进行测试。 a.下载jmeter软件 b.安装…

【RabbitMQ】2 RabbitMQ介绍与架构

目录 简介架构Connection 和Channel关系工作流程生产者发送消息的流程消费者接收消息的过程 RabbitMQ数据存储存储机制 安装和配置RabbitMQRabbitMQ常用操作命令 简介 RabbitMQ&#xff0c;俗称“兔子MQ”&#xff08;可见其轻巧&#xff0c;敏捷&#xff09;&#xff0c;是目…