MySQL désigne certains mots comme réservés, notamment des termes tels que « SELECT », « INSERT » et « DELETE », qui ont des significations prédéfinies. Utiliser ces termes comme noms de table ou de colonne sans les mettre entre guillemets déclenchera une erreur de syntaxe.
Les mots réservés ont une signification particulière dans MySQL, donc les utiliser dans des identifiants sans backticks sera interprété comme une violation de syntaxe. La documentation MySQL souligne l'importance de citer les identifiants qui contiennent des caractères spéciaux ou des mots réservés.
Pour résoudre ce problème, deux solutions s'offrent à vous :
La solution la plus recommandée est de s'abstenir d'utiliser des mots réservés comme identifiants. Cela élimine le risque d'erreurs de syntaxe provenant de mots réservés oubliés ou négligés, garantissant ainsi la portabilité du code à travers différents dialectes SQL.
Si vous renommez n'est pas réalisable, entourez les mots réservés entre des backticks (`). Cela vous permet d'utiliser ces termes dans les identifiants tout en garantissant que MySQL les reconnaît comme des chaînes plutôt que comme des mots réservés. L'utilisation de backticks garantit une syntaxe appropriée et évite toute confusion.
Considérez la requête suivante à partir de la question :
INSERT INTO user_details (username, location, key) VALUES ('Tim', 'Florida', 42)
Pour rectifier le erreur de syntaxe, le mot réservé "clé" doit être entouré backticks :
INSERT INTO user_details (username, location, `key`) VALUES ('Tim', 'Florida', 42)
En suivant ces directives, vous pouvez éviter les erreurs de syntaxe lors de l'utilisation de mots réservés dans les identifiants MySQL et maintenir l'intégrité de vos 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!