news 2026/4/17 2:48:05

MySQL表的内连接与外连接详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL表的内连接与外连接详解

1. 内连接(INNER JOIN)

1.1 基本概念

内连接是利用WHERE子句对两种表形成的笛卡尔积进行筛选,只返回两个表中连接字段相等的行。

1.2 语法格式

SELECT 字段 FROM 表1 INNER JOIN 表2 ON 连接条件 [AND 其他条件];

1.3 实际案例

显示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 WHERE ename = 'SMITH'; -- 或者将条件写在ON子句中 SELECT ename, dname FROM EMP INNER JOIN DEPT ON EMP.deptno = DEPT.deptno AND ename = 'SMITH';

1.4 内连接特点

  • 只显示两个表中匹配的记录

  • 不匹配的记录不会出现在结果中

  • 是开发中最常用的连接方式

2. 外连接(OUTER JOIN)

2.1 外连接概述

外连接分为左外连接和右外连接,用于显示不匹配的记录。

2.2 创建测试数据

-- 学生表 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);

3. 左外连接(LEFT JOIN)

3.1 基本概念

左外连接会返回左表的所有记录,以及右表中连接字段相等的记录。如果右表没有匹配的记录,则显示为NULL。

3.2 语法格式

SELECT 字段名 FROM 表名1 LEFT JOIN 表名2 ON 连接条件;

3.3 实际案例

查询所有学生的成绩,如果学生没有成绩,也要显示学生信息

SELECT * FROM stu LEFT JOIN exam ON stu.id = exam.id;

查询结果示例:

+------+------+------+-------+ | id | name | id | grade | +------+------+------+-------+ | 1 | jack | 1 | 56 | | 2 | tom | 2 | 76 | | 3 | kity | NULL | NULL | -- 左表有记录,右表无匹配 | 4 | nono | NULL | NULL | -- 左表有记录,右表无匹配 +------+------+------+-------+

3.4 左外连接特点

  • 左表记录全部显示

  • 右表只显示匹配的记录

  • 不匹配的右表字段显示为NULL

4. 右外连接(RIGHT JOIN)

4.1 基本概念

右外连接会返回右表的所有记录,以及左表中连接字段相等的记录。如果左表没有匹配的记录,则显示为NULL。

4.2 语法格式

SELECT 字段 FROM 表名1 RIGHT JOIN 表名2 ON 连接条件;

4.3 实际案例

显示所有成绩信息,即使没有对应的学生信息

SELECT * FROM stu RIGHT JOIN exam ON stu.id = exam.id;

查询结果示例:

+------+------+------+-------+ | id | name | id | grade | +------+------+------+-------+ | 1 | jack | 1 | 56 | | 2 | tom | 2 | 76 | | NULL | NULL | 11 | 8 | -- 右表有记录,左表无匹配 +------+------+------+-------+

5. 综合练习与应用

5.1 实际业务场景

列出部门名称和员工信息,同时显示没有员工的部门

方法一:使用左外连接
SELECT d.dname, e.* FROM dept d LEFT JOIN emp e ON d.deptno = e.deptno;
方法二:使用右外连接
SELECT d.dname, e.* FROM emp e RIGHT JOIN dept d ON d.deptno = e.deptno;

5.2 多表外连接应用

-- 显示所有部门、员工及工资等级信息 SELECT d.dname, e.ename, e.sal, s.grade FROM dept d LEFT JOIN emp e ON d.deptno = e.deptno LEFT JOIN salgrade s ON e.sal BETWEEN s.losal AND s.hisal;

6. 连接类型对比总结

连接类型

语法

结果描述

使用场景

内连接

INNER JOIN

只返回两个表匹配的记录

需要完全匹配的数据

左外连接

LEFT JOIN

返回左表全部+右表匹配记录

需要显示主表所有记录

右外连接

RIGHT JOIN

返回右表全部+左表匹配记录

需要显示从表所有记录

7. 实战技巧与注意事项

7.1 性能优化建议

-- 好的实践:在连接条件上使用索引 SELECT * FROM emp e INNER JOIN dept d ON e.deptno = d.deptno -- deptno字段应该有索引 WHERE e.sal > 2000; -- 避免在连接条件中使用函数 SELECT * FROM emp e INNER JOIN dept d ON e.deptno = d.deptno -- 好 -- 而不是:ON YEAR(e.hiredate) = YEAR(d.create_date) -- 不好

7.2 复杂连接查询示例

-- 查询每个部门的员工数量(包括没有员工的部门) SELECT d.dname, COUNT(e.empno) as employee_count FROM dept d LEFT JOIN emp e ON d.deptno = e.deptno GROUP BY d.deptno, d.dname; -- 查询没有员工的部门 SELECT d.dname FROM dept d LEFT JOIN emp e ON d.deptno = e.deptno WHERE e.empno IS NULL;

8. LeetCode实战题目

8.1 题目类型分析

  • rank-scores:需要使用自连接或窗口函数进行排名

  • exchange-seats:需要使用CASE语句和自连接进行座位交换

8.2 解题思路示例

-- 类似rank-scores的解法思路 SELECT s1.score, COUNT(DISTINCT s2.score) as 'rank' FROM scores s1, scores s2 WHERE s1.score <= s2.score GROUP BY s1.id ORDER BY s1.score DESC;

9. 总结

9.1 核心要点

  1. 内连接:求交集,最常用

  2. 左外连接:保留左表全部记录

  3. 右外连接:保留右表全部记录

  4. 实际开发中根据业务需求选择合适的连接方式

9.2 选择指南

  • 需要完全匹配的数据 → 使用INNER JOIN

  • 需要显示主表所有记录(如:所有学生) → 使用LEFT JOIN

  • 需要显示从表所有记录(如:所有成绩) → 使用RIGHT JOIN

  • 多表连接时注意连接顺序和性能影响

掌握这些连接方式后,能够处理各种复杂的数据查询需求,是数据库开发的重要技能。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 10:18:44

让图片学会“等你看到再出场”——懒加载全攻略

图片懒加载全解析&#xff1a;从传统 Scroll 到现代 IntersectionObserver 在前端开发的世界里&#xff0c;性能优化永远是绕不开的核心话题✨。尤其是在电商、资讯、社交这类图片密集型的页面中&#xff0c;大量图片的加载往往会成为页面性能的 “绊脚石”—— 首屏加载慢吞吞…

作者头像 李华
网站建设 2026/4/16 10:21:08

macOS 邮件客户端设置:高效管理多个邮箱账户

macOS 邮件客户端设置&#xff1a;高效管理多个邮箱账户 关键词&#xff1a;macOS 邮件客户端、多邮箱管理、智能邮箱、规则设置、通知优化 摘要&#xff1a;现代人普遍拥有多个邮箱账户&#xff08;工作邮箱、个人邮箱、订阅邮箱等&#xff09;&#xff0c;但分散管理效率低下…

作者头像 李华
网站建设 2026/4/16 7:10:36

掌握大数据领域数据溯源的实用工具

掌握大数据领域数据溯源的实用工具&#xff1a;从快递追踪到数据追踪的秘密 关键词&#xff1a;数据溯源、元数据管理、血缘分析、大数据工具、数据治理 摘要&#xff1a;在大数据时代&#xff0c;数据就像城市里川流不息的车辆——我们不仅要知道它“能到哪”&#xff0c;更要…

作者头像 李华
网站建设 2026/4/16 10:16:44

开题报告 高校医务管理系统的设计与开发

目录 高校医务管理系统的设计与开发概述系统核心功能模块技术实现要点开发价值与意义 项目技术支持可定制开发之功能亮点源码获取详细视频演示 &#xff1a;文章底部获取博主联系方式&#xff01;同行可合作 高校医务管理系统的设计与开发概述 高校医务管理系统是针对高校医疗…

作者头像 李华
网站建设 2026/4/16 7:30:34

项目模块划分

文章目录1. 服务端模块1.1 持久化数据管理中心模块1.2 虚拟机管理模块 1.3 交换路由模块 1.4 消费者管理模块 1.5 信道管理模块 1.6 连接管理模块 1.7 Broker 服务器模块 2. 客户端模块2.1 消费者管理 2.2 信道请求模块 2.3 通信连接模块 3. 项目模块关系图4. 项目创建大致思路…

作者头像 李华
网站建设 2026/4/16 7:30:38

企业AI平台运营的云计算赋能指南,AI应用架构师专业解读

企业AI平台运营的云计算赋能指南&#xff1a;AI应用架构师的专业拆解与实践路径 摘要/引言&#xff1a;企业AI平台的“成长的烦恼”与云计算的破局之道 凌晨三点&#xff0c;某制造企业的AI工程师被报警电话惊醒——生产设备预测模型的训练任务因算力不足卡住&#xff0c;而明…

作者头像 李华