我是靠谱客的博主 动人爆米花,最近开发中收集的这篇文章主要介绍mysql事务回滚例子_mysql实现事务的提交与回滚的实例详解,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

最近要对数据库的数据进行一个定时迁移,为了防止在执行过程sql语句因为某些原因报错而导致数据转移混乱,因此要对我们的脚本加以事务进行控制。

首先我们建一张tran_test表

CREATE TABLE tran_test(

f1 VARCHAR(10) NOT NULL,

f2 INT(1) DEFAULT NULL,

PRIMARY KEY (f1)

)ENGINE=INNODB CHARSET=utf8

我想对tran_test插入两条数据,但是为了防止插入中报错,因此我要把插入语句控制在一个事务内。

这时候,如果你查一下有些人的文章,许多时候会给出你这么一条答案。

START TRANSACTION;

INSERT INTO tran_test VALUES('A',1);

INSERT INTO tran_test VALUES('B',2);

ROLLBACK;

START TRANSACTION;

INSERT INTO tran_test VALUES('A',1);

INSERT INTO tran_test VALUES('B',2);

COMMIT;

看上去很简单的sql语句,并且这两句也确实能实现提交或回滚。

然而这真的能达到我们的目的吗?答案是否定的。

比如第一段,它是将你在事务中的sql语句无论对错全部进行ROLLBACK。这样绝对的回滚使得你的sql没有任何意义了。

因此我们想要真正的控制好事务,我的思路是对要执行的sql进行异常检测。如果sql没有出现异常,COM

最后

以上就是动人爆米花为你收集整理的mysql事务回滚例子_mysql实现事务的提交与回滚的实例详解的全部内容,希望文章能够帮你解决mysql事务回滚例子_mysql实现事务的提交与回滚的实例详解所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(39)

评论列表共有 0 条评论

立即
投稿
返回
顶部