MySQL的触发器全解析(创建、查看触发器)

 更新时间:2025年08月09日 11:10:42   作者:HMBBLOVEPDX  
MySQL触发器是与表关联的存储程序,当INSERT/UPDATE/DELETE事件发生时自动执行,用于维护数据一致性、日志记录和校验,优点包括自动执行,缺点是可读性差且维护难,注意外键约束可能影响触发器激活,下面跟随小编一起学习mysql的触发器知识,感兴趣的朋友一起看看吧

触发器的概念:

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删除。需注意外键约束可能影响触发器的激活。

到此这篇关于MySQL的触发器的文章就介绍到这了,更多相关mysql触发器内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL如何快速创建800w条测试数据表

    MySQL如何快速创建800w条测试数据表

    这篇文章主要介绍了MySQL如何快速创建800w条测试数据表,下面文章围绕MySQL创建测试数据表的相关资料展开详细内容,具有一的的参考价值,需要的小伙伴可以参考一下
    2022-03-03
  • MySQL8.0如何配置Path环境变量

    MySQL8.0如何配置Path环境变量

    将MySQL的bin目录添加到系统的环境变量中,可以避免每次登录MySQL时都需要输入cd命令,具体步骤如下:首先,右键桌面上的“此电脑”选择“属性”,点击左侧的“高级系统设置”,在“系统属性”对话框中选择“高级”选项卡,点击“环境变量”
    2024-11-11
  • Mybatis中的动态SQL语句解析

    Mybatis中的动态SQL语句解析

    这篇文章主要介绍了Mybatis中的动态SQL语句解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-11-11
  • mysql 添加索引的实现步骤

    mysql 添加索引的实现步骤

    索引是一种用于提高查询效率的数据结构,通过添加索引,可以加快数据的查找速度,本文主要介绍了mysql 添加索引的实现步骤,具有一定的参考价值,感兴趣的可以了解一下
    2024-07-07
  • MySQL SQL 语法参考

    MySQL SQL 语法参考

    MySQL SQL 语法参考...
    2006-12-12
  • mysql问题之slow log中出现大量的binlog dump记录的解决方法

    mysql问题之slow log中出现大量的binlog dump记录的解决方法

    今天在查看mysql中发现比较慢,然后我使用了slow log,发现出现了大量的binlog dump记录,下面我来给大家整理一下这个问题的解决办法
    2013-09-09
  • MySQL字符串截取指定字符串right使用示例

    MySQL字符串截取指定字符串right使用示例

    这篇文章主要为大家啊AI介绍了MySQL字符串截取指定字符串right使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11
  • Windows服务器下MySql数据库单向主从备份详细实现步骤分享

    Windows服务器下MySql数据库单向主从备份详细实现步骤分享

    将主服务器中的MySql数据库同步到从服务器中,使得对主服务器的操作可以即时更新到从服务器,避免主服务器因环境或者网络异常一时无法使用,达到备份效果,这篇文章整理的确实挺详细的
    2012-05-05
  • mysql字段名和关键字冲突的问题

    mysql字段名和关键字冲突的问题

    这篇文章主要介绍了mysql字段名和关键字冲突的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • MySQL中SQL Mode的查看与设置详解

    MySQL中SQL Mode的查看与设置详解

    在本篇文章里小编给各位分享的是关于MySQL中SQL Mode的查看与设置详解内容,需要的朋友们可以参考下。
    2020-03-03

最新评论