我找不到在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;
答案1:您不需要设置autocommit = 0
使用START TRANSACTION时,自动提交将保持禁用状态,直到您结束
使用COMMIT或ROLLBACK进行事务。然后自动提交模式恢复
到以前的状态。
http://dev.mysql.com/doc/refman/5.6/en/commit.html
答案1:您不需要设置autocommit = 0
使用START TRANSACTION时,自动提交将保持禁用状态,直到您结束
使用COMMIT或ROLLBACK进行事务。然后自动提交模式恢复
到以前的状态。
http://dev.mysql.com/doc/refman/5.6/en/commit.html
回答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)