主页 > 知识库 > mysql实现事务的提交与回滚的实例详解

mysql实现事务的提交与回滚的实例详解

热门标签:外呼系统电销受骗 巫师三血与酒地图标注 常州网络外呼系统开发 走过哪个省地图标注 销售语音电话机器人 莱西市地图标注 在哪里申请400电话 安徽ai电话电销机器人有效果吗 400电话申请信用卡

最近要对数据库的数据进行一个定时迁移,为了防止在执行过程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找出未提交事务的SQL实例浅析
  • MySQL找出未提交事务信息的方法分享
  • Mysql事务隔离级别之读提交详解
  • 探究MySQL中索引和提交频率对InnoDB表写入速度的影响
  • php将textarea数据提交到mysql出现很多空格的解决方法
  • mysql实现事务的提交和回滚实例
  • python连接mysql并提交mysql事务示例
  • JSP+ MySQL中文乱码问题post提交乱码解决方案
  • 详解MySQL与Spring的自动提交(autocommit)

标签:果洛 来宾 赤峰 河北 烟台 黄石 阳江 鞍山

巨人网络通讯声明:本文标题《mysql实现事务的提交与回滚的实例详解》,本文关键词  mysql,实现,事务,的,提,交与,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《mysql实现事务的提交与回滚的实例详解》相关的同类信息!
  • 本页收集关于mysql实现事务的提交与回滚的实例详解的相关信息资讯供网民参考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推荐文章