gpt4 book ai didi

mysql - 我可以在 MySQL 触发器中使用类似事务的功能吗

转载 作者:可可西里 更新时间:2023-11-01 07:06:32 27 4
gpt4 key购买 nike

我有一个插入触发器,它从表 A 的行中获取一组列值,并将其中一些插入表 B 并保留在表 C 中。我需要这个操作是一个事务,其中如果数据出现错误插入到表 B 而不是 C,整个插入操作应该回滚。

我研究了手册,它在 this 的最后说触发器中不允许事务的页面

有没有办法在mysql中实现我想要的。

最佳答案

是的,你可以,但你如何做取决于你的版本。

首先,触发器本身是事务性的;在您的情况下,您有一个插入触发器可以执行两个进一步的插入。如果其中之一失败,您将获得想要的效果。

考虑以下示例:

CREATE TABLE a (colA INT);
CREATE TABLE b (colB INT);
CREATE TABLE c (colC INT);
delimiter :
CREATE TRIGGER testtrig BEFORE INSERT ON a
FOR EACH ROW BEGIN
INSERT INTO b(colB) VALUES(NEW.colA);
INSERT INTO c(banana) VALUES (NEW.colA); -- note the faulty column name
END;:
delimiter ;

现在,当我运行失败的插入时,会发生这种情况:

mysql> INSERT INTO a VALUES (5);
ERROR 1054 (42S22): Unknown column 'banana' in 'field list'
mysql> SELECT * FROM a;
Empty set (0.00 sec)

这符合您想要的结果。

更一般地说,如果您有可用于在尝试插入之前验证数据的逻辑,则可以通过不同的方式使触发器失败:

  • 在 MySQL 5.5 中,您可以使用 SIGNAL从触发器中引发错误的机制,从而导致整个插入失败。
  • 在 MySQL 5.5 之前,您可以生成故意错误以使触发器失败。

我猜您正在使用问题中链接中的 5.0,因此如果需要,您可以执行故意错误,例如故意插入无效列,以使触发器失败。但是,正如我在回答开头所述,您在问题中描述的情况已经进行了交易处理。

关于mysql - 我可以在 MySQL 触发器中使用类似事务的功能吗,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9255608/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com