我可以在MySQL触发器中使用类似事务的功能
发布时间:2020-10-19 19:25:47 所属栏目:MySql 来源:互联网
导读:我有一个插入触发器,它从表A中的行中获取一组列值,并在表B中插入一些列值并保留在表C中.我需要此操作是一个事务,其中如果在插入数据时出现一些错误表B而不是C,应该回滚整个插入操作.我研究了手册,并在this页的最后一页说,触发器中不允许交易有没有办法在mysql
我有一个插入触发器,它从表A中的行中获取一组列值,并在表B中插入一些列值并保留在表C中.我需要此操作是一个事务,其中如果在插入数据时出现一些错误表B而不是C,应该回滚整个插入操作. 我研究了手册,并在this页的最后一页说,触发器中不允许交易 有没有办法在mysql中实现我想要的东西. 最佳答案 是的,你可以,但你如何做到这取决于你的版本.首先,触发器本身就是事务性的;在您的情况下,您有一个插入触发器,执行两次进一步插入.如果其中一个失败,您将获得所需的效果. 请考虑以下示例:
现在,当我运行一个失败的插入时,会发生这种情况:
这符合您想要的结果. 更一般地说,如果您有逻辑可以在尝试插入之前验证数据,则可以通过不同方式使触发器失败: >在MySQL 5.5中,您可以使用SIGNAL机制从触发器引发错误,从而导致整个插入失败. 我猜你正在使用你问题中的链接5.0,所以如果你需要,你可以执行故意的错误,例如故意插入无效列,以使触发失败.但是,您在问题中描述的情况已经在交易中处理,如我的答案开头所述. (编辑:鲜蔬坊站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- MYSQL数据库mysql中limit的用法深入分析
- mysql – 当ssh用于在另一台服务器上转储备份文件时,为什么
- php – mysqli_connect无法正常工作
- php – 需要将其中的字符串w / commas正确导出到CSV文件中
- Mysql入门Mysql经典的“8小时问题”
- MYSQL数据库MySQL中字符串索引对update的影响分析
- php – 运行Laravel 4迁移时出现SQL 1005错误
- Mysql必读mysql 5.7.11 zip安装配置方法图文教程
- Linux 实现mysql数据库导入导出的方法
- Mysql学习重置MySQL数据库root密码(linux/windows)