MySQL触发器中禁止使用事务控制语句,仅允许对NEW行字段赋值;税率应存为字段或通过索引化子查询获取,且历史数据不会自动重算。触发器里不能用事务控制函数MySQL 的 BEFORE INSERT 或 BEFORE UPDATE 触发器中,如果试图调用 START TRANSACTION、COMMIT 或 ROLLBACK,会直接报错 ERROR 1305 (42000): SAVEPOINT does not exist 或更常见的 ERROR 1362 (HY000): Updating of <code>NEW row is not allowed in after trigger ------ 实际上是底层禁止在触发器内开启新事务。这意味着:税费计算逻辑必须是纯计算型,不能依赖查表+更新+回滚的复合流程。比如不能先查税率表、再判断是否要插入日志、再决定扣不扣税。只允许对 NEW 行字段赋值,例如 SET NEW.tax_amount = NEW.amount * 0.06;不能执行 INSERT INTO tax_log...(除非用 AFTER 触发器,但会丢失原子性)不能调用含事务的存储过程;若封装了税率查询逻辑,该过程必须声明为 READS SQL DATA 且不含任何写操作税率变动时触发器不会自动更新历史数据触发器只作用于新增或修改的行,对已入库的老记录完全无感。如果你今天把增值税率从 6% 调到 9%,所有昨天插入的订单仍保留旧的 tax_amount,而触发器不会回头重算。这常被误认为"触发器失效",其实是设计预期。真实业务中,税率变更往往对应新合同周期,老订单按原约定执行------所以不是 bug,是 feature。上线前务必确认:历史数据是否需要重算?如需,得单独跑 UPDATE order_table SET tax_amount = amount * 0.09 WHERE created_at >= '2024-06-01';税率建议存为字段(如 tax_rate DECIMAL(5,4)),而非硬编码在触发器里,否则每次调率都要 DROP/CREATE TRIGGER若税率来自关联表(如 tax_rule),触发器里只能用 (SELECT rate FROM tax_rule WHERE ...) 子查询,且该表必须有合适索引,否则每插一行都全表扫PostgreSQL 和 MySQL 的 NEW/OLD 行行为差异MySQL 触发器中,BEFORE 可改 NEW,AFTER 不可改;PostgreSQL 则允许在 BEFORE 中返回 NULL 拦截插入,或返回修改后的 NEW 行。但两者都禁止在触发器里改其他表的行(PG 除外,可用 PERFORM 执行函数,但不推荐)。 RedClaw 百度推出的手机端万能AI Agent助手
相关推荐
TDengine (老段)6 小时前
TDengine 压缩编码机制 — 双层压缩架构与类型特化算法郑洁文6 小时前
基于Python的Web命令执行漏洞自动化检测系统yingjie1106 小时前
Scanpy vs Seurat 深度对比:Python 与 R 的单细胞分析框架谁更强?包子BI大数据7 小时前
3.openclaw小龙虾简单版安装教程程序大视界7 小时前
【Python系列课程】Pandas(四):数据统计与排序——describe、sort_values、sample苏渡苇7 小时前
Redis 持久化——RDB 快照 vs AOF 日志Cthy_hy7 小时前
Python算法竞赛:排列组合核心用法l1t7 小时前
DeepSeek总结的使用 PEG 实现运行时可扩展的 SQL 解析器这个DBA有点耶7 小时前
COUNT进阶(续):超大表去重计数的极致优化爱喝水的鱼丶7 小时前
SAP-ABAP:SAP 简单报表输出开发系列(共6篇) 第四篇:SAP 报表异常处理机制:数据校验与消息提示规范落地