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

前端之家收集整理的这篇文章主要介绍了我可以在MySQL触发器中使用类似事务的功能前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

我研究了手册,并在this页的最后一页说,触发器中不允许交易

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

最佳答案
是的,你可以,但你如何做到这取决于你的版本.

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

请考虑以下示例:

  1. CREATE TABLE a (colA INT);
  2. CREATE TABLE b (colB INT);
  3. CREATE TABLE c (colC INT);
  4. delimiter :
  5. CREATE TRIGGER testtrig BEFORE INSERT ON a
  6. FOR EACH ROW BEGIN
  7. INSERT INTO b(colB) VALUES(NEW.colA);
  8. INSERT INTO c(banana) VALUES (NEW.colA); -- note the faulty column name
  9. END;:
  10. delimiter ;

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

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

这符合您想要的结果.

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

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

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

猜你在找的MySQL相关文章