mysql 实现事务的提交与回滚

摘要:
最近,我们将对数据库数据进行定时迁移。为了防止由于某些原因导致执行过程中sql语句错误导致的数据传输混乱,我们需要控制脚本的事务。启动事务;插入测试值;插入测试值;回降;或启动交易;插入测试值;插入测试值;承诺;它看起来像一个非常简单的sql语句,这两个语句确实可以实现提交或回滚。如果sql、COMMIT和ROLLBACK中没有异常,如果捕获到异常。COMMIT在执行成功时执行,ROLLBACK在sql执行失败时执行。有两个想法可以达到我想要的效果。第一个是捕获要执行的sql的异常。我们定义一个变量t_Error,当捕捉到异常时,让t_Error=1

最近要对数据库的数据进行一个定时迁移,为了防止在执行过程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没有出现异常,COMMIT,如果捕获到了异常,则ROLLBACK。

这时候,我们就需要建一个存储过程来捕获异常。执行成功时进行COMMIT,sql执行失败时则进行ROLLBACK。

两种思路可以达到我想要的效果。

第一种是对我们要执行的sql进行异常捕获,我们再定义一个变量t_error,当捕获到异常的时候,让t_error=1。再对t_error进行条件判断,如果t_error=1则进行ROLLBACK,否则进行COMMIT。

DROP PROCEDURE IF EXISTS t_test;  
DELIMITER //  
CREATE PROCEDURE t_test()  
  BEGIN  
    DECLARE t_error INTEGER;  
    DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET t_error = 1;  
    START TRANSACTION;  
         INSERT INTO tran_test VALUES('A',1);  
     INSERT INTO tran_test VALUES('B',2);  
         IF t_error = 1 THEN  
             ROLLBACK;  
         ELSE  
             COMMIT;  
         END IF;  
END//  
CALL t_test();

另一只则是第一种的简化,即捕获到异常直接进行ROLLBACK,如果没捕获到异常,直接COMMIT

DROP PROCEDURE  IF EXISTS t_test;  
DELIMITER //  
CREATE PROCEDURE t_test()  
BEGIN  
DECLARE EXIT HANDLER FOR SQLEXCEPTION ROLLBACK;  
START TRANSACTION;  
INSERT INTO tran_test VALUES('A',1);  
INSERT INTO tran_test VALUES('B',2);  
COMMIT;  
END//  
CALL t_test()

这样,这两个insert语句便真正的被控制在了一个事务内了。

免责声明:文章转载自《mysql 实现事务的提交与回滚》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇MVC5模板部署到mono2.3.7synchronized代码块有volatile同步的功能下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

MySQL 5.7 Reference Manual】15.4.2 Change Buffer(变更缓冲)

15.4.2 Change Buffer(变更缓冲)   The change buffer is a special data structure that caches changes to secondary index pages when affected pages are not in the buffer pool. The buffere...

uboot的relocation原理详细分析

转自:http://blog.csdn.net/skyflying2012/article/details/37660265 最近在一直在做uboot的移植工作,uboot中有很多值得学习的东西,之前总结过uboot的启动流程,但uboot一个非常核心的功能没有仔细研究,就是uboot的relocation功能。 这几天研究下uboot的reloca...

解决mysql中只能通过localhost访问不能通过ip访问的问题

Mysql 默认是没有开启这个权限的(只允许使用 host:localhost,或者 host:127.0.0.1),如果想用 host:192.168.1.* ,来访问mysql ,需要手动开启这个权限进入Mysql终端输入这个命令 1.打开cmd窗口,进入MySql安装的bin目录 2.执行命令登录数据库,之后会出现一行要你输入密码的 mysql -...

MySQL下载安装、基本配置、问题处理

一 mysql介绍 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下公司。MySQL 最流行的关系型数据库管理系统,在 WEB 应用方面MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。 mysql是什么???...

Django 表操作-表之间的关系(建立在MySQL上)

Django 表操作-表之间的关系(建立在MySQL上) 数据表之间的关系有:一对多,多对多和一对一,在Django项目中做好建立表关系的准备 数据表:book,book_detail,author,publish 数据关系: 多对多:book和author 一对多:book和publish 一对一:book和book_detail 所有外键推荐建立在查询...

my.cnf配置文件实用优化

[client] 1.登陆过程自动化(这样做可以让你在命令行登陆的时候免去输入用户名和密码) host="mysql服务器地址" user="用户名" password=“密码” 2.自动切换数据库(这样做可以避免每次进入都要use 某数据库) database="你的数据库名字" [mysqld] auto-rehash 启用TAB键自动补齐 skip-...