Génération d'erreurs dans une fonction MySQL
MySQL fournit un mécanisme puissant pour définir des fonctions définies par l'utilisateur afin d'étendre les fonctionnalités de la base de données. Dans certains scénarios, il est essentiel de valider les paramètres d'entrée et de générer des erreurs lorsque des valeurs non valides sont rencontrées. MySQL propose diverses options pour gérer de telles situations.
Présentation des signaux
MySQL 5.5 introduit les signaux, un mécanisme puissant inspiré des exceptions d'autres langages de programmation. Les signaux permettent aux développeurs de générer des erreurs à partir de fonctions et de les gérer du côté de l'appelant.
Élever des signaux
Pour émettre un signal dans une fonction MySQL, utilisez la syntaxe suivante :
SIGNAL SQLSTATE 'error_code' SET MESSAGE_TEXT = 'error_message';
Dans cette instruction, 'error_code' suit le format SQLSTATE et 'error_message' est un format personnalisé message d'erreur à afficher. Par exemple :
SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Invalid parameter value';
Gestion des signaux
En dehors de la fonction, le client ou l'appelant peut gérer les signaux en utilisant la syntaxe suivante :
DECLARE errerrno INT DEFAULT 0; DECLARE errmsg VARCHAR(255) DEFAULT ''; BEGIN ... Function call ... EXCEPTION WHEN SQLSTATE '45000' THEN SELECT SQLSTATE INTO errerrno; SELECT MESSAGE_TEXT INTO errmsg; ... Handle error with errerrno and errmsg ... END;
Cet exemple montre comment gérer l'erreur SQLSTATE « 45000 » générée par la fonction et récupère à la fois le code d'erreur et le message pour une utilisation ultérieure. traitement.
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!