Existe-t-il une méthode «élégante intégrée», insensible à la casse, pour vérifier si la base de données existe?
J'ai trouvé seulement SELECT datname FROM pg_catalog.pg_database WHERE datname='dbname'
, mais c'est un chèque CS. La première chose qui vient à l'esprit pour récupérer tous les noms de base de données et les filtrer à la main, mais je pense qu'il existe une façon plus élégante de le faire.
postgresql
catalogs
Andrei Orlov
la source
la source
Réponses:
Vous pouvez utiliser:
... cependant, les noms de base de données sont sensibles à la casse, donc tenter de se connecter au nom de la base de données ne fonctionnera pas à moins que vous ne correspondiez correctement à la casse. Cela n'utilisera aucun index
dbname
, mais il est peu probable que vous disposiez de suffisamment de bases de données pour que cela soit important.Les gens ne s'en rendent pas compte parce que PostgreSQL casse les identifiants non cotés en minuscules, donc la plupart du temps, il ne respecte pas la casse pour les clients. En fait,
"DatabaseName"
et ce"databasename"
sont des choses différentes.la source
Si vous voulez une réponse vraie / fausse, vous pouvez utiliser
la source