触发器中禁止执行SELECT查询、调用存储过程、全字段比对、访问BLOB/TEXT、跨库操作及向大表插入数据;应仅保留必要字段查询、使用异步处理、批量插入并优先由应用层承担状态同步等职责。触发器里别写 SELECT 查询绝大多数性能崩盘都源于在 INSERT 或 UPDATE 触发器里执行了带 SELECT 的关联查询------尤其是查大表、查视图、或嵌套子查询。数据库会在每行变更时同步等结果,锁住源表+阻塞主事务。只保留真正必需的字段,用 WHERE 限定到单行(比如靠 NEW.id 查配置),避免 SELECT * 或无索引条件如果要查外部状态,优先改用异步方式:把关键 ID 写进日志表,由后台任务处理MySQL 8.0+ 可考虑用 INSERT ... ON DUPLICATE KEY UPDATE 替代部分"先查再更"的逻辑避免在触发器中调用存储过程或自定义函数看起来封装干净,实则隐藏了大量不可见开销。每次调用都会触发上下文切换、参数拷贝、权限校验,且 MySQL 对这类嵌套调用的执行计划几乎不优化。把简单逻辑直接展开写进触发器体,比如时间戳生成、状态码映射、字符串拼接若必须复用,确认该函数是 DETERMINISTIC 且不含 SQL;否则宁可重复几行代码PostgreSQL 中尤其注意:含 PERFORM 或 SELECT 的函数,在触发器里调用等于又埋了一层查询UPDATE 触发器慎用 OLD 和 NEW 全字段比对写 IF OLD.status != NEW.status THEN ... 没问题,但写成 IF OLD.* != NEW.* THEN(伪代码)就危险了------有些数据库会隐式序列化整行做比较,大文本字段或 JSON 列会让延迟飙升。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
小小工匠19 小时前
Redis - CPU架构对Redis性能的影响Full Stack Developme19 小时前
Hutool CollUtil 教程超梦dasgg19 小时前
连接 & 连接池完整详解(以数据库连接最常用,Redis/MQ 同理)2601_9503689119 小时前
镁钆稀土合金粉末,专业供应助力精密制造升级染指111019 小时前
19.LangChain框架7-LangChain1.0版本使用Agent(中间件实例)编程探索者小陈19 小时前
MySQL 数据库入门与实战教程(二)装不满的克莱因瓶19 小时前
从梯度下降到 Adam 优化器:掌握神经网络参数优化的核心原理未若君雅裁19 小时前
JVM 是什么:组成、运行流程与整体架构糖果店的幽灵20 小时前
时间序列处理闪电悠米20 小时前
黑马点评-秒杀优化-03_blocking_queue_async_order