Comprendre "IF EXISTS" de MySQL
Dans MySQL, la clause "IF EXISTS" est utilisée pour vérifier conditionnellement si un enregistrement existe dans un table avant d’effectuer une opération. Cependant, les utilisateurs peuvent rencontrer des problèmes lors de l'exécution de requêtes utilisant "IF EXISTS" en dehors des blocs fonctionnels.
Requêtes et erreurs d'origine
Les requêtes fournies tentent d'utiliser "IF EXISTS " mais renvoie des messages d'erreur :
IF EXISTS (SELECT * FROM gdata_calendars WHERE `group` = ? AND id = ?) SELECT 1 ELSE SELECT 0
IF ((SELECT COUNT(*) FROM gdata_calendars WHERE `group` = ? AND id = ?) > 0) SELECT 1 ELSE SELECT 0;
Problème Identification
Les erreurs se produisent parce que MySQL n'autorise pas l'utilisation des blocs de contrôle "IF" en dehors des blocs fonctionnels. Cela signifie que "IF EXISTS" ne peut pas être utilisé comme clause autonome dans une requête.
Solution
Pour que les requêtes fonctionnent, "IF EXISTS" doit être incorporé dans une fonction IF dans une sous-requête :
SELECT IF(EXISTS( SELECT * FROM gdata_calendars WHERE `group` = ? AND id = ?), 1, 0)
En fait, les valeurs booléennes dans MySQL sont renvoyées sous la forme 1 (vrai) ou 0 (faux), donc la requête simplifiée suivante fonctionnera également :
SELECT EXISTS( SELECT * FROM gdata_calendars WHERE `group` = ? AND id = ?)
En utilisant "IF EXISTS" dans une fonction IF, les requêtes géreront correctement les vérifications conditionnelles des enregistrements.
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!