0

0

mysql触发器什么时候执行_mysql触发时机解析

P粉602998670

P粉602998670

发布时间:2026-01-08 07:47:31

|

723人浏览过

|

来源于php中文网

原创

INSERT触发器执行时机取决于定义:BEFORE在数据校验通过但未写入前,可修改NEW;AFTER在行已插入、事务未提交时,NEW只读且可获取自增ID。

mysql触发器什么时候执行_mysql触发时机解析

INSERT 触发器在 INSERT 语句真正写入表之前还是之后执行?

取决于你定义的 BEFORE INSERT 还是 AFTER INSERT。MySQL 明确区分这两个时机:BEFORE 在数据校验通过、但尚未写入磁盘前触发,此时能修改 NEW 行值;AFTER 在整行已成功插入、事务尚未提交时触发,此时不能改 NEW,但可读取自增 ID 或调用外部逻辑。

常见错误是误以为 AFTER INSERT 能修改刚插入的行——它不能,NEWAFTER 中是只读的。若需动态生成字段值(如拼接 code),必须用 BEFORE INSERT

CREATE TRIGGER set_user_code 
BEFORE INSERT ON users
FOR EACH ROW
SET NEW.code = CONCAT('U_', NEW.id); -- 错!id 还没生成
-- 正确做法:用 UUID() 或其他不依赖自增 ID 的方式,或改用 AFTER + UPDATE(不推荐)

UPDATE 触发器中 NEW 和 OLD 到底代表什么?

OLD 始终是更新前的原始行快照,NEW 是即将写入的新行(BEFORE 中可改,AFTER 中只读)。关键点在于:即使 SQL 中只更新一个字段,NEW 仍包含所有列值——未显式指定的列会回填原值(不是 NULL)。

  • 判断某字段是否被修改,不能写 IF NEW.status != OLD.status 然后直接赋值,要先处理 NULL 比较(IS NULL / IS NOT NULL
  • BEFORE UPDATE 是唯一能拦截非法变更的地方,比如禁止将 status'done' 改回 'pending'
  • AFTER UPDATE 适合记录日志、更新统计表,但要注意:若触发器里再 UPDATE 同一表,可能引发递归(除非 SQL_LOG_BIN=0 或禁用嵌套)

DELETE 触发器能否访问被删行的外键关联数据?

不能直接访问。BEFORE DELETE 中只有 OLD,它只含本表字段;AFTER DELETEOLD 依然可用,但关联表的数据已不可查(除非手动 JOIN 查询,且该查询必须在事务内完成)。

典型陷阱是想在 AFTER DELETE 里做级联清理,却忘了外键约束可能已先触发(如 ON DELETE CASCADE),导致关联行已被删,再查就为空。

DeepAI
DeepAI

为天生具有创造力的人提供的AI工具

下载
  • 需要级联操作,优先用外键 ON DELETE CASCADEON DELETE SET NULL,比触发器更可靠
  • 若必须用触发器(例如要写日志或调用存储过程),放在 BEFORE DELETE,用 SELECT ... INTO 提前把关联数据捞出来存变量
  • 注意隔离级别:在 REPEATABLE READ 下,BEFORE DELETE 中查到的关联数据可能不是最新状态

触发器执行失败会导致主 SQL 失败吗?

会。MySQL 中触发器属于主 DML 语句事务的一部分,任何触发器内的错误(如除零、字段类型不匹配、违反约束)都会让整个语句回滚,并抛出明确错误,例如:

ERROR 1422 (HY000): Explicit or implicit commit is not allowed in stored function or trigger.

这意味着你不能在触发器里执行 COMMITSTART TRANSACTION,也不能调用含显式事务的存储过程。另一个常被忽略的点是性能影响:每个触发器都增加语句开销,尤其 AFTER 类型还要等写盘完成,高并发写入场景下容易成为瓶颈。

真正难调试的是隐式行为——比如某个 BEFORE INSERT 修改了 NEW.created_at,但应用层又默认设了该字段,结果值被覆盖两次;这种逻辑耦合很难一眼发现。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

676

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

320

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

346

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1093

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

357

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

674

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

571

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

412

2024.04.29

java学习网站推荐汇总
java学习网站推荐汇总

本专题整合了java学习网站相关内容,阅读专题下面的文章了解更多详细内容。

6

2026.01.08

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.7万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 785人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号