mysql如何使用FULL OUTER JOIN_mysql FULL OUTER JOIN方法

来源:这里教程网 时间:2026-02-28 20:25:23 作者:

MySQL 本身不直接支持 FULL OUTER JOIN,但你可以通过组合 LEFT JOINRIGHT JOIN 并使用 UNION 来模拟实现 FULL OUTER JOIN 的效果。

什么是 FULL OUTER JOIN

在支持 FULL OUTER JOIN 的数据库中,它会返回两个表中所有匹配和不匹配的记录。如果某行在左表或右表中没有对应数据,也会保留该行,并用 NULL 填充缺失的一侧。

MySQL 中模拟 FULL OUTER JOIN 的方法

由于 MySQL 不支持 FULL OUTER JOIN 语法,可以通过以下方式实现:

SELECT * FROM table_a a
LEFT 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

-- students 表
+----+--------+
| id | name |
+----+--------+
| 1 | Alice |
| 2 | Bob |
| 3 | Charlie|
+----+--------+

-- scores 表
+----+-------+
| id | score |
+----+-------+
| 2 | 85 |
| 3 | 90 |
| 4 | 78 |
+----+-------+

想查询所有学生及其成绩,包括没成绩的学生和没有对应学生的名字的成绩:

SELECT s.id, s.name, c.score
FROM 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 很容易实现等效逻辑。

相关推荐

热文推荐