sql >> Databáze >  >> RDS >> Mysql

transakce mysql - vrátit zpět jakoukoli výjimku

Můžete použít 13.6.7.2. DECLARE ... Syntaxe HANDLER následujícím způsobem:

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 ;

Úplný příklad naleznete v následujícím SQL Fiddle .



  1. Získání překročení časového limitu čekání na zámek; zkuste restartovat transakci, i když transakci nepoužívám

  2. SQL Server TempDB Monitoring pomocí Dynamic Management Views (DMV)

  3. Sloupec identity Oracle a vložte do select

  4. PDO::PARAM pro typ desítkové?