mysql实现事务的提交与回滚的实例详解
最近要对数据库的数据进行一个定时迁移,为了防止在执行过程sql语句因为某些原因报错而导致数据转移混乱,因此要对我们的脚本加以事务进行控制。
首先我们建一张tran_test表
CREATETABLEtran_test( f1VARCHAR(10)NOTNULL, f2INT(1)DEFAULTNULL, PRIMARYKEY(f1) )ENGINE=INNODBCHARSET=utf8
我想对tran_test插入两条数据,但是为了防止插入中报错,因此我要把插入语句控制在一个事务内。
这时候,如果你查一下有些人的文章,许多时候会给出你这么一条答案。
STARTTRANSACTION; INSERTINTOtran_testVALUES('A',1); INSERTINTOtran_testVALUES('B',2); ROLLBACK;
或
STARTTRANSACTION; INSERTINTOtran_testVALUES('A',1); INSERTINTOtran_testVALUES('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。
DROPPROCEDUREIFEXISTSt_test; DELIMITER// CREATEPROCEDUREt_test() BEGIN DECLAREt_errorINTEGER; DECLARECONTINUEHANDLERFORSQLEXCEPTIONSETt_error=1; STARTTRANSACTION; INSERTINTOtran_testVALUES('A',1); INSERTINTOtran_testVALUES('B',2); IFt_error=1THEN ROLLBACK; ELSE COMMIT; ENDIF; END// CALLt_test();
另一只则是第一种的简化,即捕获到异常直接进行ROLLBACK,如果没捕获到异常,直接COMMIT
DROPPROCEDUREIFEXISTSt_test; DELIMITER// CREATEPROCEDUREt_test() BEGIN DECLAREEXITHANDLERFORSQLEXCEPTIONROLLBACK; STARTTRANSACTION; INSERTINTOtran_testVALUES('A',1); INSERTINTOtran_testVALUES('B',2); COMMIT; END// CALLt_test()
这样,这两个insert语句便真正的被控制在了一个事务内了。
以上实例大家可以在本次测试一下,如果有其他补充和疑问可以直接联系小编,感谢大家对毛票票的支持。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。