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;

连接类型 核心特点 结果集
内连接 取两表交集 仅返回匹配数据
左外连接 左表全显示 左表全部 + 右表匹配数据
右外连接 右表全显示 右表全部 + 左表匹配数据
相关推荐
ai_coder_ai27 分钟前
论 NoSQL 数据库技术及其应用
数据库·nosql
AOwhisky2 小时前
Redis 学习笔记(第一期):概述、安装配置与核心理论
运维·数据库·redis·笔记·学习·云计算
ytttr8732 小时前
C# 定时数据库备份工具
开发语言·数据库·c#
睡不醒男孩0308232 小时前
自建 Prometheus+Grafana 与 CLUP 深度监控 PG 集群有什么区别?
数据库·oracle
就叫_这个吧2 小时前
IDEA Mybatis xml文件,实现sql语句联想,自动填入补充
xml·mysql·intellij-idea·mybatis
AOwhisky2 小时前
Redis 学习笔记(第四期):高可用与集群(哨兵 + Cluster + 容器化)
linux·运维·数据库·redis·笔记·学习·缓存
猫猫聚会Ing3 小时前
数据库设计 Prompt 提示词 - 构建与迭代
数据库
上海云盾-小余3 小时前
源站隐藏实战:规避裸 IP 被直接攻击的完整方案
数据库·网络协议·tcp/ip
微学AI4 小时前
时序大模型 TimechoAI 赋能工业时序数据底层技术优势与实操
数据库·大模型·时序大模型
北顾笙9804 小时前
MYSQL-day03
数据库·sql·mysql