Maison > base de données > tutoriel mysql > le corps du texte

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

DDD
Libérer: 2024-10-24 23:47:30
original
302 Les gens l'ont consulté

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
Copier après la connexion

Identification des erreurs

Après un examen attentif, deux erreurs de syntaxe sont identifiées :

  1. Virgules manquantes dans le gestionnaire de sortie :

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

    • L'instruction END du EXIT HANDLER manque un point-virgule final.

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;
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!