0

0

mysql触发器可以作用在哪些操作_mysql触发事件说明

P粉602998670

P粉602998670

发布时间:2026-01-18 06:41:35

|

664人浏览过

|

来源于php中文网

原创

只有 INSERT、UPDATE、DELETE 三类 DML 操作能触发 MySQL 触发器;TRUNCATE 是 DDL 操作,通过重建表绕过行级处理,故不触发 DELETE 触发器。

mysql触发器可以作用在哪些操作_mysql触发事件说明

MySQL 触发器只能作用在 INSERTUPDATEDELETE 这三类 DML 操作上,不支持 SELECT、TRUNCATE、ALTER、DROP 等其他语句触发。这是硬性限制,不是配置问题。

哪些操作能触发 MySQL 触发器?

只有对表执行以下三种显式数据变更操作时,才会激活对应触发器:

  • INSERT:包括 INSERT INTO ... VALUESINSERT INTO ... SELECT(但注意:INSERT ... ON DUPLICATE KEY UPDATE 会触发 BEFORE INSERTAFTER INSERT,而冲突走 UPDATE 分支时还会额外触发 BEFORE UPDATE/AFTER UPDATE
  • UPDATE:哪怕 SET 的值和原值完全相同(如 UPDATE t SET x=5 WHERE id=1,而 x 原本就是 5),只要语句执行成功,就会触发 —— MySQL 不做“实际变更”判断
  • DELETE:包括 DELETE FROMTRUNCATE —— 但注意:TRUNCATE 是 DDL 操作,**不会触发任何 DELETE 触发器**,这点极易踩坑

为什么 TRUNCATE 不触发 DELETE 触发器?

因为 TRUNCATE 在 MySQL 中本质是「重建表」:它先删掉原表文件,再用空结构重建,绕过了逐行处理逻辑。所以即使你写了 AFTER DELETE 触发器,TRUNCATE table_name 也完全无视它。

  • ✅ 正确做法:真要清空并触发逻辑,改用 DELETE FROM table_name
  • ⚠️ 风险提示:大表用 DELETE 可能锁表久、生成大量 binlog;若必须用 TRUNCATE,需手动补全触发器该做的事(比如清空日志表、重置计数器等)
  • ? 验证方式:执行 SHOW TRIGGERS LIKE 'your_table',确认触发器类型是否为 DELETE,再测试 TRUNCATE 是否无反应

BEFORE vs AFTER:时间点决定你能做什么

触发时机直接约束你能访问和修改的数据范围:

OpenArt
OpenArt

在线AI绘画艺术图片生成器工具

下载
  • BEFORE INSERT:可用 NEW.col = ... 修改即将插入的值(比如自动补 created_at、校验 email 格式);但不能读 OLD(不存在)
  • BEFORE UPDATE:可读 OLD.col(原值)、写 NEW.col(新值);适合做字段级审计(如记录谁改了价格)、拦截非法更新(如 IF NEW.price > OLD.price * 1.1 THEN SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = '涨价超10%禁止'; END IF;
  • AFTER DELETE:只能读 OLD.col(被删行的最后快照),适合写归档、发通知、清理关联缓存;但此时行已不存在,不能再对原表做 UPDATE 同一主键(会报错)

常见误用场景与后果

这些操作看似合理,实则 MySQL 明确禁止,会直接报错:

  • 在触发器里执行 INSERT/UPDATE/DELETE 当前触发器所属的同一张表(即“递归修改自身表”)→ 报错 ERROR 1442 (HY000): Can't update table 'xxx' in stored function/trigger because it is already used by statement which invoked this stored function/trigger.
  • BEFORE 触发器中对 NEW 赋值一个非法类型(如给 INT 字段赋字符串 'abc')→ 触发器执行失败,整个原始语句回滚
  • 在触发器里调用存储函数,而该函数又尝试修改表 → 同样触发 1442 错误(MySQL 对“表依赖链”有严格静态检查)
DELIMITER //
CREATE TRIGGER check_price_before_update 
BEFORE UPDATE ON products
FOR EACH ROW
BEGIN
  IF NEW.price < 0 THEN
    SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Price cannot be negative';
  END IF;
  -- ✅ 允许:修改 NEW 值
  SET NEW.updated_at = NOW();
END //
DELIMITER ;

触发器不是万能钩子,它的能力边界非常清晰:只响应那三个动词、只在行级生效、不能碰自己表、不感知事务外操作。真正难的从来不是写出来,而是想清楚——这件事非得靠触发器做不可吗?很多业务逻辑放在应用层更可控、更易测、更易排查。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

663

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

246

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

281

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

514

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

253

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

529

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

599

2023.08.14

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

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

精品课程

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

共48课时 | 1.8万人学习

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

共3课时 | 0.3万人学习

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

共1课时 | 797人学习

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

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