内部连接出错 - 尽管存在表但未找到表

Posted

技术标签:

【中文标题】内部连接出错 - 尽管存在表但未找到表【英文标题】:error with inner join - table not found although it's there 【发布时间】:2017-05-20 04:46:55 【问题描述】:
SELECT * FROM "animalTbl" 
  INNER JOIN "deathTbl" 
  ON animalTbl.animalID = deathTbl.animalID;

这是我的代码,当我运行它时会出现这样的问题

 ERROR: missing FROM-clause entry for table "animaltbl"
LINE 3: ON animalTbl.animalID = deathTbl.animalID;
  ^

【问题讨论】:

使用相同的区分大小写的表名或别名来限定列 不要使用带引号的标识符 - 这样可以省去你的麻烦 postgresql.org/docs/current/static/… 【参考方案1】:

postgres 中的对象名称通常不区分大小写,但使用双引号引用它们会强制区分大小写。假设from 子句是正确的,您应该与您的符号保持一致,并在on 子句中使用与fromjoin 子句中相同的符号:

SELECT     *
FROM       "animalTbl" 
INNER JOIN "deathTbl" ON "animalTbl".animalID = "deathTbl".animalID;
-- Here -----------------^---------^------------^--------^

【讨论】:

【参考方案2】:

您必须使用相同的区分大小写的表名或别名来限定列

试试这个:

SELECT * FROM "animalTbl" a
  INNER JOIN "deathTbl" d
  ON a.animalID = d.animalID

【讨论】:

以上是关于内部连接出错 - 尽管存在表但未找到表的主要内容,如果未能解决你的问题,请参考以下文章