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 :
Vilignes manquantes dans Exit Handler :
Point-virgule manquant :
Le code corrigé
Le code corrigé est comme suit :
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;
Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.
Copyright© 2022 湘ICP备2022001581号-3