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);
解决方案
您的查询可能会返回错误,因为第二个表中可能有多行具有相同的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);
推荐阅读
- ios - 当 Rails 解析其提交的参数时,SwiftUI 总是将字段值提交为 Optional
- c# - 插入值后刷新 DataGridView
- sql-server - SQL Server 未捕获链接服务器超时错误
- ios - UISplitViewController - 在 iPad Portrait 中展开和折叠主视图
- python - 为什么列表推导不适用于使用等号更新字典元素
- pandas - 回填和增量一?
- swift - 在将 textField 传递给函数之前如何测试它是否为空:
- python - 当 content_type 是字典时,单元测试很热门
- node.js - 大文件不会传输到 Elastic Beanstalk 托管应用程序
- javascript - 覆盖 JS 原型函数