双向外连接

ele*_*tum 8 mysql sql

假设我们有一个表A:

itemid mark
1      5
2      3
Run Code Online (Sandbox Code Playgroud)

和表B:

itemid mark
1      3
3      5
Run Code Online (Sandbox Code Playgroud)

我想加入A.itemid = B.itemid的A*B左右两种方式.即结果:

itemid A.mark B.mark
1      5      3
2      3      NULL
3      NULL   5
Run Code Online (Sandbox Code Playgroud)

有没有办法在MySQL的一个查询中执行此操作?

Nic*_*lay 7

它被称为完全外连接,并且从它的文档判断它在MySQL本身不受支持.您可以使用UNION解决此限制,如我链接到的页面的注释中所述.

[编辑]由于其他人发布了片段,你走了.您可以在链接页面上看到说明.

SELECT *
FROM A LEFT JOIN B ON A.id = B.id
UNION ALL
SELECT *
FROM A RIGHT JOIN B ON A.id = B.id
WHERE A.id IS NULL
Run Code Online (Sandbox Code Playgroud)