在 MySQL 中,表连接(Table Join)是将多个表中的数据通过关联条件组合在一起的核心操作
1. 内连接(INNER JOIN)
作用:返回两个表中 满足连接条件 的行(交集)。
-
仅返回匹配的行。
-
如果某行在其中一个表中没有匹配项,则该行不显示。
2. 左连接(LEFT JOIN / LEFT OUTER JOIN)
作用:返回左表(LEFT JOIN
左侧的表)所有行,右表中 匹配的行,若右表无匹配则填充 NULL
-
左表数据完整保留,右表无匹配时显示
NULL
。 -
常用于查找“左表存在但右表不存在”的数据。
SELECT employees.name, departments.department_name
FROM employees
LEFT JOIN departments ON employees.department_id = departments.department_id;
3. 右连接(RIGHT JOIN / RIGHT OUTER JOIN)
作用:返回右表所有行,左表中 匹配的行,若左表无匹配则填充 NULL
。
-
右表数据完整保留,左表无匹配时显示
NULL
。 -
用途与
LEFT JOIN
类似,但方向相反。
SELECT employees.name, departments.department_name
FROM employees
RIGHT JOIN departments ON employees.department_id = departments.department_id;
4. 全外连接(FULL OUTER JOIN)
-
返回所有数据,无论是否匹配。
-
适用于需要同时保留两表全部数据的场景。
SELECT employees.name, departments.department_name
FROM employees
LEFT JOIN departments ON employees.department_id = departments.department_id
UNION
SELECT employees.name, departments.department_name
FROM employees
RIGHT JOIN departments ON employees.department_id = departments.department_id;
5. 交叉连接(CROSS JOIN)
-
结果行数 = 左表行数 × 右表行数。
-
慎用,可能导致海量数据。
SELECT products.product_name, categories.category_name
FROM products
CROSS JOIN categories;
总结
连接类型 | 描述 | 常用场景 |
---|---|---|
INNER JOIN | 返回匹配行 | 精确关联查询 |
LEFT JOIN | 保留左表全部行 | 查找左表存在但右表缺失的数据 |
RIGHT JOIN | 保留右表全部行 | 查找右表存在但左表缺失的数据 |
FULL OUTER JOIN | 保留两表全部行(需模拟) | 合并两表所有数据 |
CROSS JOIN | 笛卡尔积 | 生成组合数据(谨慎使用) |