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助手
相关推荐
ClouGence1 小时前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因zzzzzz3102 小时前
当产品经理说这个很简单:我用Python自动化处理奇葩需求的实战指南雪隐2 小时前
个人电脑玩AI-06让5060 Ti给你打工——不光能画画,Qwen3-TTS还能学人说话,连我老板都信了!飞将3 小时前
从零实现数据库(2)——HashIndex + IndexManager兵慌码乱14 小时前
面向桌面端的资产管理系统分层架构设计与核心模块实现hboot15 小时前
AI工程师第三课 - 机器学习基础顾林海20 小时前
Agent入门阶段-编程基础-Python:流程控制呱呱复呱呱1 天前
Django CBV 源码解读:一个请求是怎么找到你的 get() 方法的Nturmoils1 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT曲幽1 天前
刚部署的 LibreTranslate 频频翻车?我掏出了 20 年前的 StarDict 词典,用 FastAPI 搭了个本地词典翻译 API