Maison >développement back-end >tutoriel php >Pourquoi ma requête Postgresql renvoie-t-elle « la colonne « Smith » n'existe pas » même si la colonne existe ?
Nom de colonne non reconnu dans la requête Postgresql
Lorsque vous essayez d'exécuter une simple instruction SELECT dans Postgresql, vous pouvez rencontrer l'erreur "colonne" Smith n'existe pas." Cela peut être déroutant, surtout lorsque vous savez que la colonne à laquelle vous faites référence existe effectivement dans votre base de données.
Cause fondamentale :
Le problème vient de la façon dont Postgresql gère les noms de colonnes entre guillemets et sans guillemets. Dans ce cas, vous avez placé des guillemets doubles autour du nom de colonne "lName" pour indiquer qu'il s'agit d'une correspondance exacte. Cependant, la valeur à laquelle vous la comparez, « Smith », n'est pas placée entre guillemets.
Solution :
Pour résoudre ce problème, assurez-vous que les deux le nom de la colonne et la valeur de comparaison sont placés entre guillemets du même type. Dans Postgresql, il est généralement recommandé d'utiliser des guillemets simples pour les chaînes littérales :
SELECT * FROM employee WHERE "lName" LIKE 'Smith'
De plus, vous pouvez envisager d'inclure un caractère générique dans votre expression LIKE. Sans caractère générique, une comparaison LIKE équivaut à une vérification d'égalité. Si vous aviez l'intention d'effectuer une correspondance partielle, incluez un caractère générique, tel que « % » :
SELECT * FROM employee WHERE "lName" LIKE '%Smith%'
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!