在 MySQL 多表查询中,表连接 是核心知识点,也是日常开发中使用频率极高的查询方式。表连接主要分为内连接和外连接,外连接又细分为左外连接、右外连接。
实际业务中,数据不会全部存在一张表里,比如员工信息存在
emp表,部门信息存在dept表,学生信息存在stu表,成绩信息存在exam表。想要关联查询多张表的数据 ,就必须用到表连接,它能将多张表通过关联字段组合,返回我们需要的完整结果。

一、内连接
内连接 是取两张表的交集,只返回满足连接条件的匹配数据,也是开发中最常用的连接方式。
本质:对两张表的笛卡尔积用
ON/WHERE条件筛选,只保留匹配行。
语法:

备注:INNER可以省略,直接写JOIN就是内连接。
1.1 经典案例
需求:查询员工SMITH的姓名和对应部门名称。
-
传统写法(等价内连接)
SELECT ename, dname
FROM EMP, DEPT
WHERE EMP.deptno=DEPT.deptno
AND ename='SMITH';

-
标准内连接写法
SELECT ename, dname
FROM EMP
INNER JOIN DEPT
ON EMP.deptno=DEPT.deptno
AND ename='SMITH';

两种写法执行结果一致,推荐使用标准内连接,逻辑更清晰、可读性更强。
二、外连接
外连接与内连接最大的区别:不满足连接条件的数据也会保留 ,会显示驱动表的全部数据。外连接分为左外连接 和右外连接。
2.1 左外连接
左侧表完全显示 ,即使右表没有匹配数据,左表数据也会保留,右表字段补NULL。

实战案例
先创建学生表stu和成绩表exam:
-- 学生表
CREATE TABLE stu (id INT, name VARCHAR(30));
INSERT INTO stu VALUES(1,'jack'),(2,'tom'),(3,'kity'),(4,'nono');
-- 成绩表
CREATE TABLE exam (id INT, grade INT);
INSERT INTO exam VALUES(1, 56),(2,76),(11, 8);

- 查询所有学生的成绩,如果这个学生没有成绩,也要将学生的个人信息显示出来
当左边表和右边表没有匹配时,也会显示左边表的数据!!!


结果:jack、tom显示对应成绩,kity、nono无成绩,成绩字段为NULL,但学生信息完整保留。
2.2 右外连接
右侧表完全显示 ,即使左表没有匹配数据,右表数据也会保留,左表字段补NULL。

实战案例
- 需求:显示所有成绩数据,无对应学生的成绩也要展示。

结果:11号成绩无对应学生,学生字段为NULL,但成绩信息完整保留。
-
列出部门名称和这些部门的员工信息,同时列出没有员工的部门
SELECT d.dname, e.*
FROM dept d
LEFT JOIN emp e
ON d.deptno=e.deptno;

| 连接类型 | 核心特点 | 结果集 |
|---|---|---|
| 内连接 | 取两表交集 | 仅返回匹配数据 |
| 左外连接 | 左表全显示 | 左表全部 + 右表匹配数据 |
| 右外连接 | 右表全显示 | 右表全部 + 左表匹配数据 |