数据库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没有出现异常,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语句便真正的被控制在了一个事务内了。

以上实例大家可以在本次测试一下,如果有其他补充和疑问可以直接联系小米,感谢大家对米云问答的支持。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL事务处理是数据库管理系统中最重要的概念之一。在MySQL中,事务是指一组SQL语句,这些语句要么全部执行成功,要么全部不执行。如果在执行事务的过程中出现了错误,MySQL会自动回滚所有的操作,保证数据的一致性和完整性。 在MySQL中,事务的处理方式有两种:自动提交和手动提交。默认情况下,MySQL采用的是自动提交的方式,即每个SQL语句执行完毕后都会自动提交事务。如果需要手动提交事务,则需要使用BEGIN、COMMIT和ROLLBACK等语句来控制事务提交回滚。 下面是一个MySQL事务处理的实例: 1. 创建一个测试表: CREATE TABLE `test` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(50) DEFAULT NULL, `age` int(11) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8; 2. 开始一个事务: BEGIN; 3. 向测试表中插入一条数据: INSERT INTO `test` (`name`,`age`) VALUES ('Tom',20); 4. 向测试表中插入一条错误数据: INSERT INTO `test` (`name`,`age`) VALUES ('Jerry','twenty'); 5. 提交事务: COMMIT; 6. 查看测试表中的数据: SELECT * FROM `test`; 在这个实例中,我们使用了BEGIN、COMMIT和ROLLBACK等语句来控制事务提交回滚。在执行第4步时,由于插入了错误的数据MySQL会自动回滚所有的操作,保证数据的一致性和完整性。最后,我们可以通过SELECT语句来查看测试表中的数据,可以发现只有一条数据被插入成功。 总之,MySQL事务处理可以确保数据的一致性和完整性,是数据库管理系统中最重要的概念之一。在实际应用中,我们需要根据具体的业务需求来选择自动提交或手动提交的方式,并且在编写SQL语句时需要考虑到事务处理的影响。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值