mysql transaction - roll back on any exception

前端 未结 3 1076
攒了一身酷
攒了一身酷 2020-11-27 03:19

Is it possible to roll back automatically if any error occurs on a list of mysql commands?

for example something along the lines of:

begin transactio         


        
3条回答
  •  孤城傲影
    2020-11-27 03:41

    You can use 13.6.7.2. DECLARE ... HANDLER Syntax in the following way:

    DELIMITER $$
    
    CREATE PROCEDURE `sp_fail`()
    BEGIN
        DECLARE `_rollback` BOOL DEFAULT 0;
        DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET `_rollback` = 1;
        START TRANSACTION;
        INSERT INTO `tablea` (`date`) VALUES (NOW());
        INSERT INTO `tableb` (`date`) VALUES (NOW());
        INSERT INTO `tablec` (`date`) VALUES (NOW()); -- FAIL
        IF `_rollback` THEN
            ROLLBACK;
        ELSE
            COMMIT;
        END IF;
    END$$
    
    DELIMITER ;
    

    For a complete example, check the following SQL Fiddle.

提交回复
热议问题