Sql Oracle从一个表中提取数据并使用它从另一个表中提取数据
我在Oracle DB中有两个表,一个表包含A、B列,另一个表包含A、B、C列。两个表中的前两列相同,但两个表中的A、B列具有不同的数据,因此两个表中的A->B关系不同 所以我想运行一个查询来获取包含Table1A,Table1B,Table2C的数据,其中Table1B=Table2BSql Oracle从一个表中提取数据并使用它从另一个表中提取数据,sql,oracle,Sql,Oracle,我在Oracle DB中有两个表,一个表包含A、B列,另一个表包含A、B、C列。两个表中的前两列相同,但两个表中的A、B列具有不同的数据,因此两个表中的A->B关系不同 所以我想运行一个查询来获取包含Table1A,Table1B,Table2C的数据,其中Table1B=Table2B Select Tab1.A, Tab1.B, (select Tab2.C from Tab2 where Tab1.B=Tab2.B ) FROM Tab1 WHERE Tab1.A IN (1,2,3,4
Select Tab1.A, Tab1.B, (select Tab2.C from Tab2 where Tab1.B=Tab2.B )
FROM Tab1 WHERE Tab1.A IN (1,2,3,4,5);
您的查询可能会返回错误,因为第二个表中可能有多行具有相同的
B
值。为什么不直接使用JOIN
SELECT Tab1.A, Tab1.B, Tab2.C
FROM Tab1 JOIN
Tab2
ON Tab1.B = Tab2.B
WHERE Tab1.A IN (1, 2, 3, 4, 5);
您的查询可能会返回错误,因为第二个表中可能有多行具有相同的
B
值。为什么不直接使用JOIN
SELECT Tab1.A, Tab1.B, Tab2.C
FROM Tab1 JOIN
Tab2
ON Tab1.B = Tab2.B
WHERE Tab1.A IN (1, 2, 3, 4, 5);
你的问题是什么?另外,示例数据和所需结果也会有所帮助。对于我的查询,第三列结果显示为null,而不是从第二个表中选取值。那么您的查询有什么问题?另外,示例数据和所需结果也会有所帮助。对于我的查询,第三列结果显示为null,而不是从第二个表中选取值。