FULL OUTER JOIN 返回两表所有记录,无匹配时用 NULL 填充;MySQL 中可通过 LEFT JOIN 与 RIGHT JOIN 加 UNION 模拟实现,确保字段一致,UNION 去重或 UNION ALL 保留重复。

MySQL 本身不直接支持 FULL OUTER JOIN,但你可以通过组合 LEFT JOIN 和 RIGHT JOIN 并使用 UNION 来模拟实现 FULL OUTER JOIN 的效果。
什么是 FULL OUTER JOIN
在支持 FULL OUTER JOIN 的数据库中,它会返回两个表中所有匹配和不匹配的记录。如果某行在左表或右表中没有对应数据,也会保留该行,并用 NULL 填充缺失的一侧。
MySQL 中模拟 FULL OUTER JOIN 的方法
由于 MySQL 不支持 FULL OUTER JOIN 语法,可以通过以下方式实现:
SELECT * FROM table_a aLEFT JOIN table_b b ON a.id = b.id
UNION
SELECT * FROM table_a a
RIGHT JOIN table_b b ON a.id = b.id;
说明:
- LEFT JOIN 获取左表全部记录,右表无匹配则补 NULL
- RIGHT JOIN 获取右表全部记录,左表无匹配则补 NULL
- UNION 合并结果并自动去重(若允许重复可用 UNION ALL)
实际示例
假设有两个表:students 和 scores
+----+--------+
| id | name |
+----+--------+
| 1 | Alice |
| 2 | Bob |
| 3 | Charlie|
+----+--------+
-- scores 表
+----+-------+
| id | score |
+----+-------+
| 2 | 85 |
| 3 | 90 |
| 4 | 78 |
+----+-------+
想查询所有学生及其成绩,包括没成绩的学生和没有对应学生的名字的成绩:
SELECT s.id, s.name, c.scoreFROM students s
LEFT JOIN scores c ON s.id = c.id
UNION
SELECT c.id, s.name, c.score
FROM students s
RIGHT JOIN scores c ON s.id = c.id;
结果将包含 id=1(无成绩)、id=4(无姓名)的记录,完整覆盖两边的数据。
注意事项
- 确保两个 SELECT 查询的字段数量和类型一致
- UNION 会自动去除重复行;如需保留重复,使用 UNION ALL(性能更高)
- 当左右都有匹配时,LEFT 与 RIGHT 结果相同,UNION 会合并为一行
基本上就这些。MySQL 虽然不原生支持 FULL OUTER JOIN,但用 LEFT + RIGHT + UNION 很容易实现等效逻辑。









