[英]Selecting ambiguous column from subquery
假设我们有以下查询:
select c.a, c.b, c.d
from
(select * from
tab1 join tab2
on tab1.id = tab2.id)c
我收到以下错误: ERROR: 42702: column reference "d" is ambiguous
我该如何解决? 我可以做类似c.tab1.id
事情吗?
您可以这样写查询:
SELECT a, b, d FROM (SELECT tab1.a AS a, tab1.b AS b, tab2.c AS c, tab2.d AS d
FROM tab1 JOIN tab2 ON tab1.id = tab2.id)c;
发生错误是因为tab1
和tab2
都有一个名为d
的列。
最简单的解决方案是消除子查询:
select ?.a, ?.b, ?.d
from tab1 join
tab2
on tab1.id = tab2.id
?
是列来源表格的占位符。
如果需要子查询,则应类似地使用限定的列名,而不要使用select *
,以便确定列的来源。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.