首页 > 解决方案 > 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);

标签: sqloracle

解决方案


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

推荐阅读