目录

触发器的概念:

创建触发器:

查看触发器:

查看当前数据库的所有触发器的定义:

查看当前数据中某个触发器的定义:

从系统information_schema的TRIGGERS表中查询"salary_check_trigger"触发器的信息:

删除触发器:

优点:

缺点:

注意:


触发器的概念:

MySQL触发器(‌Trigger‌)是一种与数据库表关联的特殊存储程序,当指定事件(如INSERT、UPDATE、DELETE)发生时由数据库‌自动触发执行‌。它用于在数据变更前后执行自定义逻辑,确保数据的一致性和业务规则。

触发器是由事件来触发某个操作,这些事件包括INSERT、UPDATE、DELETE事件。所谓事件就是指用户的动作或者出发某项行为。如果定义了触发程序,当数据库执行这些语句的时候,就相当于事件发生了,就会自动激发触发器执行相应的操作。

创建触发器:

CREATE TRIGGER 触发器名称
{BEFORE | AFTER}{INSERT | UPDATE | DELETE} ON 表名
FOR EACH ROW
触发器执行的语句块;

表名:表示触发器监控的对象。

BEFORE | AFTER:表示触发的时间。BEFORE表示在事件之前触发,AFTER表示在事件之后触发。

INSERT | UPDATE | DELETE:表示触发的事件。INSERT插入记录时触发,UPDATE更新记录时触发,DELETE删除记录时触发。

触发器执行的语句块:可以是单条SQL语句,也可以是BEGIN...END结构组成的复合语句块。

如果使用了BEGIN...END:

DELIMITER $
CREATE TRIGGER 触发器名
{BEFORE | AFTER} {INSERT | DELETE | UPDATE} ON 表名
FOR EACH ROW
BEGIN
执行的SQL语句
END $
DELIMITER ;

查看触发器:

查看数据库中已经存在的触发器的定义、状态和语法信息等。

查看当前数据库的所有触发器的定义:

SHOW TRIGGERS;

查看当前数据中某个触发器的定义:

SHOW CREATE TRIGGER 触发器名;

从系统information_schema的TRIGGERS表中查询"salary_check_trigger"触发器的信息:

SELECT * FROM information_schema.TRIGGERS;

删除触发器:

DROP TRIGGER [IF EXISTS] 触发器名;

优点:

触发器可以确保数据的完整性。可以帮助记录操作日志。还可以用在操作数据前,对数据进行合法性检查。

缺点:

触发器最大的一个问题就是可读性差。因为触发器存储在数据库中,并且由事件驱动,这就意味这触发器有可能不受应用层的控制。

相关数据的变更,可能会导致触发器出错。

注意:

如果在子表中定义了外键约束,并且外键制定了ON UPDATE/DELETE CASCADE/SET NULL子句,此时修改父表被引用的键值或者删除附表被引用的记录行时,也会引起子表的修改和删除操作,此时基于子表的UPDATE和DELETE语句定义的触发器并不会被激活。

总结:

MySQL触发器是一种与表关联的特殊存储程序,在指定事件(INSERT/UPDATE/DELETE)发生时自动执行。通过CREATE TRIGGER语法创建,可设置在操作前(BEFORE)或后(AFTER)触发,支持单条SQL或复合语句块。触发器能确保数据一致性、记录操作日志和数据校验,但存在可读性差、不易维护的缺点。可通过SHOW TRIGGERS查看触发器,使用DROP TRIGGER删除。需注意外键约束可能影响触发器的激活。

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

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

相关文章

基于ubuntu搭建gitlab

原文地址:基于ubuntu搭建gitlab – 无敌牛 欢迎参观我的网站:无敌牛 – 技术/著作/典籍/分享等 之前介绍了一个使用 git openssh-server 搭建一个极简 git 库的方法,感兴趣可以查看往期文章:手搓一个极简远端git库 – 无敌牛 。…

测试GO前沿实验室:为水系电池研究提供多维度表征解决方案

测试GO前沿实验室:为水系电池研究提供多维度表征解决方案随着全球能源转型加速,水系电池因其高安全性、低成本和环境友好特性,成为下一代储能技术的重要发展方向。测试狗前沿实验室针对水系电池研发中的关键科学问题,整合先进表征…

Spring Boot 中 YAML 配置文件详解

Spring Boot 中 YAML 配置文件详解 在 Spring Boot 项目中,配置文件是不可或缺的一部分,用于自定义应用行为、覆盖默认设置。除了传统的 properties 文件,Spring Boot 对 YAML(YAML Ain’t Markup Language)格式提供了…

Milvus安装可视化工具,attu,保姆级

安装包链接:GitHub - zilliztech/attu: Web UI for Milvus Vector Databasehttps://github.com/zilliztech/attu?tabreadme-ov-file 下滑 举例:windows:下载安装,然后就可以连接了(安装完打开后如果需要输入用户名密码…

避免“卡脖子”!如何减少内存I/O延迟对程序的影响?

单来说,内存 IO 就像是计算机的 “数据高速公路”,负责在内存和其他设备(如硬盘、CPU 等)之间传输数据。它的速度和效率直接影响着计算机系统的整体性能。 你有没有想过,当你点击电脑上的一个应用程序,它是…

V4L2摄像头采集 + WiFi实时传输实战全流程

📖 推荐阅读:《Yocto项目实战教程:高效定制嵌入式Linux系统》 🎥 更多学习视频请关注 B 站:嵌入式Jerry V4L2摄像头采集 WiFi实时传输实战全流程 1. 实战场景概述 目标: 嵌入式设备(如RK3588/正点原子开发…

Java 之 设计模式

1.单例模式1. ​​饿汉式(Eager Initialization)​​​​核心原理​​:类加载时立即创建实例,通过静态变量直接初始化。​​代码示例​​:public class Singleton {private static final Singleton INSTANCE new Sing…

[激光原理与应用-185]:光学器件 - BBO、LBO、CLBO晶体的全面比较

一、相同点非线性光学晶体属性BBO、LBO、CLBO均为非中心对称晶体,具备非线性光学效应,广泛应用于激光频率转换(如倍频、三倍频、和频、差频)、光学参量振荡(OPO)及电光调制等领域。宽透光范围三者均覆盖紫外…

Android APN加载耗时优化可行性分析

背景 根据Android系统底层机制和行业实践,本文讨论 APN 加载耗时从4.2s降至0.8s的数据合理性和技术可行性,需结合具体优化手段和硬件环境综合分析。 以下是关键判断依据及行业参考: ⚙️ 一、APN加载耗时基准参考 未优化场景的典型耗时 首次开机或重置后:APN需从apns-con…

mysql进阶-sql调优

概述优化索引在MySQL初阶的课程中已经介绍了索引,我们知道InnoDB存储引擎使⽤B树作为索引默认的数据结构来组织数据,为频繁查询的列建⽴索引可以有效的提升查询效率,那么如何利⽤索引编写出⾼效的SQL查询语句?以及如何分析某个查询…

海量数据处理问题详解

1.从a,b两个文件各存放50亿个url(每个url大小为64B),如何在内存为4G中查找a,b中相同的url 计算各文件存放大小:50亿*64B 大约为320G,而内存只有4G,显然存放不下,此时我们…

AI 记忆管理系统:工程实现设计方案

本文档为《从“健忘”到“懂我”:构建新一代AI记忆系统》中所述理念的详细工程实现方案。它将聚焦于技术选型、模块设计、数据流转和核心算法,为开发团队提供清晰的落地指引。 1. 系统架构与技术选型 为实现分层记忆与读写分离的设计理念,我们…

Linux驱动学习day26天(RS485)

一、原理通过芯片将232信号转换成485信号,485表示0和1的方法:Va - Vb 的电压差在2~6V时表示1,Va - Vb 的电压差在-2~-6V时表示0。这样传输不容易受到干扰,并且传输距离长。我们需要做的事情就是发送:使能DE(driver ena…

从零构建TransformerP1-了解设计

欢迎来到啾啾的博客🐱。 记录学习点滴。分享工作思考和实用技巧,偶尔也分享一些杂谈💬。 有很多很多不足的地方,欢迎评论交流,感谢您的阅读和评论😄。 目录引言1 概念回顾1.1 序列任务1.1.1 将序列变成模型…

JVM 终止机制详解:用户线程与守护线程

用户线程未执行完是否会阻止 JVM 终止?答案是:取决于线程类型。让我详细解释: 核心规则 #mermaid-svg-bg5xpyMAeRWNGGk2 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-bg5xpyMAe…

Linux Vim 常用快捷键

Vim中最常用的快捷键,熟练掌握它们可以大大提高编辑效率。移动光标h- 左移j- 下移k- 上移l- 右移w- 移动到下一个单词开头b- 移动到上一个单词开头e- 移动到单词末尾0- 移动到行首$- 移动到行尾gg- 移动到文件开头G- 移动到文件末尾:n- 跳转到第n行插入模式i- 在光标…

【Bellman负环】Cycle Finding

题目翻译给定一个有向图,你的任务是判断它是否包含负环,并给出这样一个环的示例。输入 第一行输入两个整数 n 和 m:分别表示节点数和边数。节点编号为 1, 2, ..., n。 接下来 m 行描述边,每行有三个整数 a, b, c:表示存…

数据结构(六):树与二叉树

一、树的基本概念树的定义树(Tree)是由 n(n ≥ 0)个节点组成的有限集合,当 n 0 时称为空树。非空树中:有且仅有一个根节点(Root);其余节点可以划分为若干个互不相交的子…

《Linux运维总结:Shell 脚本日志输出工具》

总结:整理不易,如果对你有帮助,可否点赞关注一下? 更多详细内容请参考:Linux运维实战总结 一、Shell 脚本日志输出工具 1、提供的 logger() 函数是一个非常实用的 Shell 脚本日志输出工具,它支持带时间戳和…

select ... for update阻塞

总结阻塞规则:当前事务持有的锁 (来自 SELECT ... FOR UPDATE)其他事务尝试的操作是否会被阻塞?原因排他锁 (X Lock) 在行 R 上SELECT ... FROM ... (普通查询)否读快照 (MVCC),不需要锁排他锁 (X Lock) 在行 R 上SELECT ... FROM ... FOR UP…