首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Oracle ON colA = colB:如何包含来自colA的空行

Oracle ON colA = colB:如何包含来自colA的空行
EN

Stack Overflow用户
提问于 2015-11-25 12:08:31
回答 4查看 80关注 0票数 0

我有两张桌子。

TABLE_A

代码语言:javascript
复制
| SURNAME | COL_X |

TABLE_B

代码语言:javascript
复制
| ID | COL_Y |

COL_X可以映射到表B中的ID列,我需要来自COL_Y的值。

下面的查询工作正常,除非COL_X在TABLE_A中有一个空值。我想把这些行包括进去。我该怎么做?

代码语言:javascript
复制
SELECT a.SURNAME, b.COL_Y
FROM TABLE_A a
INNER JOIN TABLE_B b
ON a.COL_X = b.ID

我尝试了以下查询,但它返回重复的行,因此不能使用。

代码语言:javascript
复制
SELECT a.SURNAME, b.COL_Y
FROM TABLE_A a
INNER JOIN TABLE_B b
ON a.COL_X = b.ID or a.COL_X IS NULL
EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2015-11-25 12:16:30

您已经尝试使用一个内部联接,它显示两个表中的所有行。您可能可以使用左联接来执行您期望的操作:

代码语言:javascript
复制
SELECT a.SURNAME, b.COL_Y
FROM TABLE_A a
LEFT JOIN TABLE_B b
  ON a.COL_X = b.ID
票数 1
EN

Stack Overflow用户

发布于 2015-11-25 12:14:59

只需使用LEFT JOIN而不是INNER JOIN

代码语言:javascript
复制
SELECT a.SURNAME, b.COL_Y
FROM TABLE_A a
LEFT JOIN TABLE_B b
  ON a.COL_X = b.ID
票数 1
EN

Stack Overflow用户

发布于 2015-11-25 12:17:42

你应该尝试一个外部连接,例如-

代码语言:javascript
复制
SELECT a.SURNAME, b.COL_Y
FROM TABLE_A a
RIGHT OUTER JOIN TABLE_B b
ON a.COL_X = b.ID or a.COL_X IS NULL
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33916170

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档