Oracle从一个表中获取数据,并使用它从另一个表中获取数据

时间:2019-02-22 20:53:17

标签: sql oracle

我在Oracle DB中有2个表,一个表包含A,B列,另一个表包含A,B,C列。两个表中的前两列相同,但是,两个表中的A,B列均不同数据,因此两个表的A-> B关系不同。

所以我想运行一个查询以获取包含Table1 A,Table1 B,Table2C的数据,其中Table1 B = Table2 B;

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);

1 个答案:

答案 0 :(得分:2)

您的查询可能会返回错误,因为第二个表中可能有多个行具有相同的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);