问题 MySql存储过程,事务和回滚


我找不到在MySql存储过程中使用事务的最佳方法。我要 ROLLBACK 如果有任何失败:

BEGIN

    SET autocommit=0;
    START TRANSACTION;

    DELETE FROM customers;
    INSERT INTO customers VALUES(100);
    INSERT INTO customers VALUES('wrong type');

    COMMIT;
END

1)是 autocommit=0 需要?

2)如果是第二个 INSERT 第一个打破(当然是它) INSERT 没有回滚。程序只是继续下去 COMMIT。我怎么能阻止这个?

3)我发现我可以 DECLARE HANDLER,我应该使用此指令还是有一种更简单的方法来说明如果任何命令失败,存储过程应该 ROLLBACK 也失败了?

DECLARE HANDLER 工作正常,但由于我有MySql版本5.1我不能使用 RESIGNAL。因此,如果发生错误,将不会通知来电者:

DECLARE EXIT HANDLER FOR SQLEXCEPTION 
BEGIN
    ROLLBACK; 
    -- RESIGNAL; not in my version :(
END;

START TRANSACTION;

1009
2017-09-29 06:47


起源



答案:


答案1:您不需要设置autocommit = 0

使用START TRANSACTION时,自动提交将保持禁用状态,直到您结束   使用COMMIT或ROLLBACK进行事务。然后自动提交模式恢复   到以前的状态。

http://dev.mysql.com/doc/refman/5.6/en/commit.html


10
2017-11-08 10:23



该页面上的另一个声明 To disable autocommit mode implicitly for a single series of statements, use the START TRANSACTION statement - fyrye


答案:


答案1:您不需要设置autocommit = 0

使用START TRANSACTION时,自动提交将保持禁用状态,直到您结束   使用COMMIT或ROLLBACK进行事务。然后自动提交模式恢复   到以前的状态。

http://dev.mysql.com/doc/refman/5.6/en/commit.html


10
2017-11-08 10:23



该页面上的另一个声明 To disable autocommit mode implicitly for a single series of statements, use the START TRANSACTION statement - fyrye


回答2的不同方法:你可以使用布尔变量来知道你是应该COMMIT还是ROLLBACK。例如:

BEGIN

DECLARE `should_rollback` BOOL DEFAULT FALSE;
DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET `should_rollback` = TRUE;

START TRANSACTION;

DELETE FROM customers;
INSERT INTO customers VALUES(100);
INSERT INTO customers VALUES('wrong type');

IF `should_rollback` THEN
    ROLLBACK;
ELSE
    COMMIT;
END IF;
END

或者,你可以使用你非常有用的3)


1
2017-08-25 20:25