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;

连接类型 核心特点 结果集
内连接 取两表交集 仅返回匹配数据
左外连接 左表全显示 左表全部 + 右表匹配数据
右外连接 右表全显示 右表全部 + 左表匹配数据
相关推荐
无小道10 小时前
Mysql——索引
mysql·索引·搜索
炸炸鱼.10 小时前
PostgreSQL 日常维护速查手册
数据库·oracle
元宝骑士11 小时前
深度解析 ROW_NUMBER() 窗口函数:从入门到实战避坑指南
后端·mysql
014-code11 小时前
MySQL 常用业务 SQL
数据库·sql·mysql
知识分享小能手12 小时前
MongoDB入门学习教程,从入门到精通,MongoDB的选择片键 - 完整知识点(16)
数据库·学习·mongodb
知识分享小能手12 小时前
MongoDB入门学习教程,从入门到精通,MongoDB分片配置完全指南(15)
数据库·学习·mongodb
y = xⁿ12 小时前
【MySQL】数据库的脏读,不可重复读和幻读,覆盖索引是什么,索引类型有哪些
数据库·mysql
小冷coding12 小时前
【面试】结合项目整理的场景面试题,覆盖 Java 基础、锁、多线程、数据库、分布式锁 / 事务、消息中间件等核心维度
java·数据库·面试
kcuwu.12 小时前
Python 正则表达式从入门到实战
数据库·python·正则表达式