"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Pourquoi mes procédures stockées MySQL ne parviennent-elles pas à exécuter les transactions avec succès ?

Pourquoi mes procédures stockées MySQL ne parviennent-elles pas à exécuter les transactions avec succès ?

Publié le 2024-11-18
Parcourir:308

Why Do My MySQL Stored Procedures Fail to Execute Transactions Successfully?

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 :

  1. Vilignes manquantes dans Exit Handler :

    • Dans la déclaration EXIT HANDLER, il doit y avoir des virgules séparant les conditions.
  2. Point-virgule manquant :

    • Il manque un point-virgule de fin à l'instruction END de EXIT HANDLER.

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;
Dernier tutoriel Plus>

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