触发器中禁止执行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助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
程序边界2 小时前
NFS环境下数据库安装报错解析(上篇):一个诡异的“权限门“事件解救女汉子2 小时前
MongoDB 聚合管道中处理空值以正确计算百分比完成度2301_773553622 小时前
bootstrap怎么修改模态框(Modal)背景遮罩层的颜色花月C2 小时前
Python Web框架-FastAPI尘埃落定wf2 小时前
2026 年 LangChain (记忆)Memory 怎么用?三个核心类 + 完整代码示例m0_674294642 小时前
TypeScript 5.2 升级引发 NestJS 构建失败的解决方案熊文豪2 小时前
KingbaseES 行标识机制全解:OID、ROWID 与自增主键的底层逻辑LiAo_1996_Y2 小时前
如何强制phpMyAdmin通过HTTPS安全访问_配置ForceSSL参数与Web代理端证书部署weixin_424999362 小时前
如何正确实现“破纪录次数统计”算法(高低分突破计数)