Maison >base de données >tutoriel mysql >Comment réparer « SQLSTATE[42000] : Erreur de syntaxe ou violation d'accès : 1064 Vous avez une erreur dans votre syntaxe SQL » dans PDO ?

Comment réparer « SQLSTATE[42000] : Erreur de syntaxe ou violation d'accès : 1064 Vous avez une erreur dans votre syntaxe SQL » dans PDO ?

Linda Hamilton
Linda Hamiltonoriginal
2024-12-31 09:13:20482parcourir

How to Fix

Erreur de syntaxe PDO : "Vous avez une erreur dans votre syntaxe SQL"

Lors de l'exécution d'une requête SQL avec PDO, vous pouvez rencontrer le erreur "SQLSTATE[42000] : Erreur de syntaxe ou violation d'accès : 1064 Vous avez une erreur dans votre syntaxe SQL." Cette erreur se produit souvent lorsqu'un mot-clé réservé est utilisé comme nom de colonne sans guillemets appropriés.

L'exemple fourni utilise le nom de colonne « from » dans l'instruction INSERT. "from" est un mot-clé réservé en SQL et doit être cité à l'aide de guillemets (`).

$sql = "INSERT INTO messages (`from`, `to`, `name`, `subject`, `message`) VALUES (:from, :to, :name, :subject, :message)";

De plus, "to" est également un mot-clé réservé et doit également être cité.

$sql = "INSERT INTO messages (`from`, `to`, `name`, `subject`, `message`) VALUES (:from, :to, :name, :subject, :message)";

Une autre option consiste à renommer la colonne pour éviter d'utiliser un mot-clé réservé. Par exemple, au lieu de « from », vous pouvez utiliser « sender » ou « from_email ».

Renommer la colonne ou citer le mot-clé réservé devrait résoudre l'erreur de syntaxe et permettre à la requête de s'exécuter correctement.

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