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;

连接类型 核心特点 结果集
内连接 取两表交集 仅返回匹配数据
左外连接 左表全显示 左表全部 + 右表匹配数据
右外连接 右表全显示 右表全部 + 左表匹配数据
相关推荐
zh1570231 分钟前
JavaScript中WorkerThreads解决服务端计算瓶颈
jvm·数据库·python
代码AI弗森5 分钟前
一文理清楚“算力申请 / 成本测算 / 并发评估”
java·服务器·数据库
摇滚侠1 小时前
expdp 查看帮助
java·数据库·oracle
流年似水~1 小时前
MCP协议实战:从零搭建一个让Claude能“看见“数据库的工具服务
数据库·人工智能·程序人生·ai·ai编程
2401_871492851 小时前
Vue.js监听器watch利用回调函数处理级联下拉框数据联动
jvm·数据库·python
志栋智能2 小时前
超自动化安全:构建智能安全运营的核心引擎
大数据·运维·服务器·数据库·安全·自动化·产品运营
zhoutongsheng3 小时前
C#怎么实现Swagger文档 C#如何在ASP.NET Core中集成Swagger自动生成API文档【框架】
jvm·数据库·python
WinterKay3 小时前
【开源】我写了一个轻量级本地数据库浏览工具,支持 MySQL/Redis 只读查询
数据库·mysql·开源
zxrhhm4 小时前
Oracle 索引完整指南
数据库·oracle
程序猿乐锅5 小时前
【Tilas|第三篇】多表SQL语句
数据库·经验分享·笔记·学习·mysql