假设我们有一个表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的一个查询中执行此操作?
它被称为完全外连接,并且从它的文档判断它在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)
| 归档时间: |
|
| 查看次数: |
1166 次 |
| 最近记录: |