首页 >数据库 >mysql教程 >为什么更新触发器内的表会导致错误 #1442,如何解决此问题?

为什么更新触发器内的表会导致错误 #1442,如何解决此问题?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-12-23 03:03:33215浏览

Why Does Updating a Table Inside a Trigger Cause Error #1442, and How Can This Be Solved?

触发器陷阱:更新触发器引用的表

在触发器中更新同一表可能会导致问题。提供了一个这样的实例,其中尝试使用更新后执行的触发器来更新 products_score 表。

触发器(如提供的代码所示)尝试根据以下条件计算和更新 votes_total 列:同一 products_score 表中其他列(votes_1、votes_2、...、votes_5)的值。然而,当触发此更新时,会出现错误:

#1442 - Can't update table 'products_score' in stored function/trigger because it is already used by statement which invoked this stored function/trigger.

解决方案:使用 BEFORE 触发器

要解决此问题,必须将触发器修改为在行更新之前执行,而不是之后执行。通过在更新之前执行,触发器可以访问和修改分配给 votes_total 列的新值。

使用 BEFORE update 子句修改后的触发器如下:

CREATE TRIGGER upd_total_votes BEFORE UPDATE ON products_score
FOR EACH ROW
BEGIN
    SET new.votes_total = new.votes_1 + new.votes_2 + new.votes_3 + new.votes_4 + new.votes_5;
END;

With通过此修改,触发器在实际行更新发生之前成功计算并更新 votes_total 列,从而解决了错误并允许实现所需的功能。

以上是为什么更新触发器内的表会导致错误 #1442,如何解决此问题?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn