我找不到在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;
答案 0 :(得分:10)
答案1:您不需要设置autocommit = 0
使用START TRANSACTION,自动提交将保持禁用状态,直到您结束 使用COMMIT或ROLLBACK进行事务。然后自动提交模式恢复 到以前的状态。
答案 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)