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

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

【讨论】:

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

InnoDB:尽管表的 .frm 文件存在,但无法从 InnoDB 的内部数据字典打开表

尽管显示从方法块内部更改的值,但从 setter 设置私有值“余额”时出错

如何内部连接来自不同数据上下文的表? [复制]

mysqli内部连接:其他表中不存在数据

MySQL内部连接查询以获取其他表中不存在的记录

内部连接错误