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

Abh*_*hek 5 mysql triggers transactions

我有一个插入触发器,其采用一组列值从行表A和插入它们中的一些在表B和残留在表C.我需要这种操作是,其中,如果有一定的误差,同时数据被插入在一个事务中表B而不是C,应该回滚整个插入操作.

我学的是手动和它说,在最后的这个页面,交易未在允许触发器

有没有办法在mysql中实现我想要的东西.

Jer*_*yth 4

是的,您可以,但具体操作方式取决于您的版本。

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

考虑以下示例:

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 ;
Run Code Online (Sandbox Code Playgroud)

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

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

这符合您想要的结果。

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

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

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