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 ?

Pourquoi ma requête Postgresql renvoie-t-elle « la colonne « Smith » n'existe pas » même si la colonne existe ?

DDD
DDDoriginal
2024-12-02 06:08:10827parcourir

Why Does My Postgresql Query Return

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!

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