Lors de l'exécution de requêtes MySQL nécessitant des noms de table variables, les utilisateurs peuvent rencontrer des erreurs telles que celle signalée dans la question. Cet article vise à explorer l'utilisation des instructions préparées et à fournir une solution à ce problème spécifique.
L'erreur mentionnée : "[Err] 1064 - Vous avez une erreur dans votre Syntaxe SQL" indique que le serveur MySQL est incapable d'interpréter correctement la syntaxe de la requête. L'utilisation de la variable "@table" directement dans l'instruction de requête pourrait en être la cause.
Les instructions préparées offrent une approche fiable pour gérer les requêtes dynamiques impliquant des noms de tables variables. Ils vous permettent de définir un modèle de requête et de remplacer dynamiquement les valeurs ultérieurement. Dans ce cas, nous pouvons définir un modèle de requête à l'aide de la fonction CONCAT pour créer le nom de la table variable.
Considérez les étapes suivantes :
SET @id := '47'; SET @table := CONCAT(@id, '_2013_2014_voucher'); SET @qry1 := CONCAT('SELECT * FROM ', @table);
Cela configure le modèle de requête dynamique dans le variable @qry1.
Ensuite, préparez l'instruction à l'aide de la commande PREPARE :
PREPARE stmt FROM @qry1;
Maintenant, vous pouvez exécuter l'instruction préparée plusieurs fois, en remplaçant différents noms de table selon vos besoins :
EXECUTE stmt;
La même approche peut être appliquée aux requêtes de suppression. Construisez simplement un modèle de requête dynamique à l'aide de CONCAT et préparez-le comme indiqué ci-dessus :
SET @qry2 := CONCAT('DELETE FROM ', @table, ' WHERE id = @id');
L'utilisation d'instructions préparées avec des noms de table dynamiques dans MySQL vous permet d'exécuter efficacement des requêtes avec des noms de table variables et avec élégance. N'oubliez pas d'utiliser la fonction CONCAT pour la concaténation de chaînes et d'exploiter la puissance des instructions préparées pour une flexibilité et des performances améliorées des requêtes.
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!