MySQL 触发器:为新行设置值并更新同一个表中的另一行
在 MySQL 中,触发器是强大的机制,允许您当表中发生某些事件时执行特定操作。一个常见的用例是为新插入的行 (NEW) 设置值,同时更新同一表中的另一行。但是,尝试此操作时可能会出现常见错误:
错误 1442:无法更新存储函数/触发器中的表“split”,因为它已被调用此存储函数/触发器的语句使用。
出现此错误是因为触发器无法更新触发它的同一个表。要克服此限制,请遵循以下替代方法:
使用存储过程:
创建一个处理插入和更新操作的存储过程,而不是使用触发器。下面是一个示例:
<code class="sql">DELIMITER $$ CREATE PROCEDURE split_before_ins(IN startDate DATE, IN endDate DATE, IN tcOfficeFee DECIMAL, IN globalFee DECIMAL) BEGIN -- Insert a new row with the provided parameters INSERT INTO im.split (startDate, endDate, tcOfficeFee, globalFee) VALUES (startDate, endDate, tcOfficeFee, globalFee); -- Update the previous row's endDate UPDATE im.split SET endDate = DATE_SUB(startDate, INTERVAL 1 DAY) WHERE procKey = (SELECT procKey FROM im.split ORDER BY procKey DESC LIMIT 1) AND endDate = '20501231'; END$$ DELIMITER ;</code>
过程用法:
要调用存储过程,请执行以下命令:
<code class="sql">CALL split_before_ins('2023-01-01', '2024-12-31', 10.00, 100.00);</code>
此存储过程方法允许您在单个事务上下文中执行所需的操作,避免使用触发器更新调用它的同一个表时遇到的错误。
以上是MySQL中插入新行后如何更新同一个表中的行?的详细内容。更多信息请关注PHP中文网其他相关文章!