当前位置:  开发笔记 > 后端 > 正文

双向外连接

如何解决《双向外连接》经验,为你挑选了1个好方法。

假设我们有一个表A:

itemid mark
1      5
2      3

和表B:

itemid mark
1      3
3      5

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

itemid A.mark B.mark
1      5      3
2      3      NULL
3      NULL   5

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



1> Nickolay..:

它被称为完全外连接,并且从它的文档判断它在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

推荐阅读
李桂平2402851397
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有