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

首先我们建一张tran_test表

CREATE TABLE tran_test( f1 VARCHAR(10) NOT NULL, f2 INT(1) DEFAULT NULL, PRIMARY KEY (f1) )ENGINE=INNODB CHARSET=utf8

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

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语句无论对错全部进行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();
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()

更多相关文章

  1. MySQL系列多表连接查询92及99语法示例详解教程
  2. 《Android和PHP最佳实践》官方站
  3. android用户界面之按钮(Button)教程实例汇
  4. Android(安卓)- Manifest 文件 详解
  5. TabHost与RadioGroup结合完成的菜单【带效果图】5个Activity
  6. Android的Handler机制详解3_Looper.looper()不会卡死主线程
  7. Android(安卓)UI开发第十七篇——Android(安卓)Fragment实例(Lis
  8. Android——Activity四种启动模式
  9. Selector、shape详解(一)

随机推荐

  1. Android屏幕保持常亮的三种方法
  2. Android(安卓)招聘
  3. Android 常用对话框Dialog封装
  4. 【ImageView】图片自适应及android:scale
  5. Android传感器的运用之ACCELEROMETER
  6. Androidの自定义对话框AlertDialog(一)
  7. Android快速生成MVP 模式代码
  8. Android(安卓)Drawable Resource学习(二)、
  9. Android : android 9.0 audio 接口分析
  10. Android Studio 之 AndroidManifest.xml