MySql存储过程,事务和回滚

时间:2010-09-29 06:47:53

标签: mysql stored-procedures commit rollback

我找不到在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并且也会失败?< / p>

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

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

START TRANSACTION;

2 个答案:

答案 0 :(得分:10)

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

  

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

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

答案 1 :(得分:1)

答案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)