列名中带有大写字母的 Postgres 查询

Posted

技术标签:

【中文标题】列名中带有大写字母的 Postgres 查询【英文标题】:Postgres query with uppercase letters in Column name 【发布时间】:2021-08-13 10:16:49 【问题描述】:

我搜索并遵循了各种在线指南,但是没有成功使用以下查询,虽然没有给出错误,但它没有得到预期的结果。

table gBInfo:
(columns) id,userId, fromGB, fromGBId      

table User:
(columns) id, firstName, lastName

查询:

select "id", "firstName", "fromGB" 
from "User" join "gBInfo"
on 'User.id' = 'gBInfo.userId';

如何让这个查询工作,在列名和表名中使用大写字母。

【问题讨论】:

你真的应该避免那些可怕的引用标识符。他们的麻烦比他们值得的要多得多。 wiki.postgresql.org/wiki/… 【参考方案1】:

单引号用于字符串常量,而不是标识符。并且多部分标识符的每一部分都需要单独引用:

select "id", "firstName", "fromGB" 
from "User" 
  join "gBInfo" on "User".id = "gBInfo"."userId";

条件'User.id' = 'gBInfo.userId' 只是将字符串值User.id 与字符串值gBInfo.userId 进行比较,这显然不相等。

【讨论】:

以上是关于列名中带有大写字母的 Postgres 查询的主要内容,如果未能解决你的问题,请参考以下文章

python 得到 postgres 查询结果 可以有列名

Hibernate - 在 postgres 中带有触发器的 saveAndFlush

如何在 Postgres 中删除区分大小写?

PostgreSQL中的大写列名

PostgreSQL中的大写列名

PostgreSQL中的大写列名