Résoudre les problèmes transactionnels dans les procédures stockées MySQL
Lorsqu'ils tentent d'implémenter des transactions dans une procédure stockée MySQL, les développeurs peuvent rencontrer des erreurs inattendues. Cet article explorera la syntaxe et les erreurs logiques qui peuvent empêcher l'exécution réussie des procédures stockées transactionnelles.
Le cas : une transaction échouée
Un développeur rencontre un problème lorsque tenter d'implémenter des transactions dans une procédure stockée. Malgré le respect de la documentation MySQL, la procédure ne s'exécute pas correctement et entraîne l'impossibilité d'enregistrer les modifications. Après une inspection plus approfondie, le code semble être syntaxiquement correct.
Analyse du code
L'extrait de code fourni est le suivant :
BEGIN DECLARE poid INT; DECLARE EXIT HANDLER FOR SQLEXCEPTION SQLWARNING BEGIN ROLLBACK; END START TRANSACTION; -- ADD option 5 INSERT INTO product_option(product_id,option_id,required) VALUES(insertedProductID,5,0); SET poid = (SELECT LAST_INSERT_ID()); INSERT INTO product_option_value(product_option_id,product_id,option_id,option_value_id,quantity,subtract,price,price_prefix,points,points_prefix,weight,weight_prefix) VALUES(poid,insertedProductID,5,50,0,0,4.99,'+',0,'+',0,'+'); -- ADD option 12 INSERT INTO product_option(product_id,option_id,required) VALUES(insertedProductID,12,1); -- ADD option 13 INSERT INTO product_option(product_id,option_id,required) VALUES(insertedProductID,13,0); COMMIT; END
Identification des erreurs
Après un examen attentif, deux erreurs de syntaxe sont identifiées :
Virgules manquantes dans le gestionnaire de sortie :
Point-virgule manquant :
Le code corrigé
Le code corrigé le code est le suivant :
BEGIN DECLARE poid INT; DECLARE EXIT HANDLER FOR SQLEXCEPTION, SQLWARNING BEGIN ROLLBACK; END; START TRANSACTION; -- ADD option 5 INSERT INTO product_option(product_id,option_id,required) VALUES(insertedProductID,5,0); SET poid = (SELECT LAST_INSERT_ID()); INSERT INTO product_option_value(product_option_id,product_id,option_id,option_value_id,quantity,subtract,price,price_prefix,points,points_prefix,weight,weight_prefix) VALUES(poid,insertedProductID,5,50,0,0,4.99,'+',0,'+',0,'+'); -- ADD option 12 INSERT INTO product_option(product_id,option_id,required) VALUES(insertedProductID,12,1); -- ADD option 13 INSERT INTO product_option(product_id,option_id,required) VALUES(insertedProductID,13,0); COMMIT; END;
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!