mysql触发器 事务_我可以在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,所以如果你需要,你可以执行故意的错误,例如故意插入无效列,以使触发失败.但是,您在问题中描述的情况已经在交易中处理,如我的答案开头所述.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值