Maison >base de données >tutoriel mysql >Comment corriger les erreurs de syntaxe dans les procédures stockées MySQL pour les opérations transactionnelles ?

Comment corriger les erreurs de syntaxe dans les procédures stockées MySQL pour les opérations transactionnelles ?

Patricia Arquette
Patricia Arquetteoriginal
2024-10-24 18:54:29649parcourir

How to Fix Syntax Errors in MySQL Stored Procedures for Transactional Operations?

Procédures stockées transactionnelles dans MySQL

Lors de la modification des procédures stockées MySQL pour les rendre transactionnelles, il est essentiel de suivre la syntaxe correcte et de gérer tout potentiel efficacement les erreurs.

Utilisation de transactions dans une procédure stockée

La procédure stockée fournie tente d'effectuer des opérations transactionnelles dans son corps à l'aide des instructions BEGIN et COMMIT. Cependant, il rencontre une erreur empêchant son enregistrement.

Erreurs de syntaxe

Lors de l'examen du code, deux erreurs de syntaxe critiques sont identifiées :

  • Virgules manquantes dans le gestionnaire de sortie :
    La déclaration EXIT HANDLER nécessite des virgules séparant les conditions (SQLEXCEPTION, SQLWARNING). Selon la documentation sur la syntaxe, les virgules sont obligatoires.
  • Point-virgule manquant dans le gestionnaire de sortie :
    L'instruction END du gestionnaire de sortie doit se terminer par un point-virgule. Toutes les instructions dans MySQL, y compris les gestionnaires de sortie, nécessitent un terminateur point-virgule.

Code corrigé

Pour corriger les erreurs de syntaxe, la partie corrigée du code doit ressemble à ceci :

<code class="sql">DECLARE EXIT HANDLER FOR SQLEXCEPTION, SQLWARNING
BEGIN
    ROLLBACK;
END;</code>

Une fois ces erreurs corrigées, la procédure stockée devrait fonctionner comme prévu, vous permettant d'y effectuer des opérations transactionnelles.

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!

Déclaration:
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