MySQL【表的内外连接】

在 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;

连接类型 核心特点 结果集
内连接 取两表交集 仅返回匹配数据
左外连接 左表全显示 左表全部 + 右表匹配数据
右外连接 右表全显示 右表全部 + 左表匹配数据
相关推荐
安当加密2 小时前
MySQL 防勒索终极防线:TDE 透明加密 + DBG 动态权限控制双重保护实战
数据库·mysql·adb
sevenlin2 小时前
MySQL数据库(SQL分类)
数据库·sql·mysql
czlczl200209252 小时前
Mysql log 杂知识
数据库·mysql
大榕树信息科技2 小时前
动环监控系统提升机房管理的智能化与人性化体验
数据库·人工智能·信息可视化·数据中心·动环监控系统
吾诺2 小时前
Java进阶,时间与日期,包装类,正则表达式
java·mysql·正则表达式
码哥字节2 小时前
Redis 8.0~8.4 重要更新,新特性很强!
数据库·redis·缓存
未来龙皇小蓝2 小时前
【MySQL-索引调优】05:索引相关概念
数据库·mysql·性能优化
码农阿豪2 小时前
MySQL 动态分区管理:自动化与优化实践
数据库·mysql·自动化
givemeacar2 小时前
redis 使用
数据库·redis·缓存