news 2026/6/15 15:47:16

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/6/9 21:17:41

​ Android 基础入门教程​3.8 Gestures(手势)

3.8 Gestures(手势) 分类 Android 基础入门教程 本节引言&#xff1a; 周六不休息&#xff0c;刚剪完了个大平头回来&#xff0c;继续码字~ 好的&#xff0c;本节给大家带来点的是第三章的最后一节——Gestures(手势)&#xff0c; 用过魅族手机的朋友相信对手势肯定是不陌生…

作者头像 李华
网站建设 2026/6/12 22:04:07

什么是Redis的大Key和热Key?你们的项目一般是怎么解决的?

一、首先我们要搞清楚大key和热key是什么。 1. 大Key 通常以Key的大小和Key中成员的数量来综合判定。比如Key本身的Value过大&#xff0c;一个String类型的Key&#xff0c;它的值为10 MB&#xff1b;Key中的成员数过多&#xff1a;一个ZSET类型的Key&#xff0c;它的成员数量为…

作者头像 李华
网站建设 2026/6/5 12:40:40

基于WEB的超市销售管理系统设计 开题报告

目录研究背景与意义系统目标关键技术预期功能模块创新点研究方法进度计划参考文献项目技术支持可定制开发之功能亮点源码获取详细视频演示 &#xff1a;文章底部获取博主联系方式&#xff01;同行可合作研究背景与意义 随着电子商务和数字化管理的普及&#xff0c;传统超市需通…

作者头像 李华
网站建设 2026/5/29 13:46:22

利用AI提升开题报告质量,大幅减少人工修改时间

工具对比速览 工具名称 核心功能 适用场景 效率评分 特色优势 AIBiYe 开题报告生成/降重 中文论文全流程 ★★★★★ 国内院校适配度高 AICheck 初稿生成/格式检查 快速产出框架 ★★★★☆ 结构化输出优秀 AskPaper 文献综述辅助 外文文献处理 ★★★★ 跨…

作者头像 李华
网站建设 2026/6/13 19:06:25

代码重构指南:优化建议系统

代码重构指南&#xff1a;优化建议系统关键词&#xff1a;代码重构、优化建议系统、代码质量、软件开发、算法原理、实战案例摘要&#xff1a;本文围绕代码重构的优化建议系统展开&#xff0c;旨在为开发者提供全面的技术指导。首先介绍了代码重构及优化建议系统的背景&#xf…

作者头像 李华
网站建设 2026/6/10 14:00:41

从 TCP 到 HTTP 再到 RPC:网络协议的三次抽象革命

从 TCP 到 HTTP 再到 RPC:网络协议的三次抽象革命 这是一个非常经典、也极其容易被误解的问题。 很多讨论都会演变成: HTTP 和 RPC 谁更先进? gRPC 是不是要取代 REST? TCP 既然这么强,为什么还要搞这么多协议? 真正的答案只有一句话: 它们不是替代关系,而是一次又一…

作者头像 李华