MySQL表的内连和外连

之前我们讲解MySQL的查询方法,今天我们来讲解一下内连接和外链接,话不多说,现在开始啦,对了,今天是五一的第一天,祝大家五一快乐!!

一、连接的本质

在关系型数据库中,数据往往分散在多个表中。为了在一次查询中获取完整的信息,就需要将这些表按照某种规则"连接"起来。连接的底层是笛卡尔积:即让表A的每一行和表B的每一行两两组合,形成一张巨大的临时表。然后,再通过连接条件从中筛选出真正有意义的行


二、内连接

内连接是最常用的连接方式,它只返回两个表中完全满足连接条件的行。不匹配的行会被直接丢弃。

  • 传统写法 :在FROM中列出多个表,用WHERE子句指定连接条件。其实我们之前写的等值连接多数就是内连接。

  • 标准写法 :使用INNER JOIN ... ON ...语法,语义更清晰。

特点:结果集中绝不会出现因不匹配而产生的空值

select 字段 from 表1 inner join 表2 on 连接条件 and 其他条件;

注:前面学习的都是内连接

例如查询员工及其部门名,只会显示有部门的员工;既没有部门的员工,也没有员工的部门,都不会出现

下面是一个样例

显示SMITH的名字和所在部门名称


三、外连接

外连接会保留某个表中的全部记录 ,即使它在另一张表中找不到匹配。缺失的字段用NULL填充。外连接分为左外连接和右外连接

为了更好的讲解知识点,下面是我们预先创建的database与tables;

1. 左外连接

使用LEFT JOIN,会完整显示左侧表 的所有行,右表中无匹配的列置为NULL

典型场景:你需要以左表为主体来查看信息。比如"列出所有学生,并显示他们的成绩"。即使某个学生从未参加过考试,他的个人信息也要保留,成绩部分留空。

例子:查询所有学生的成绩,如果这个学生没有成绩,也要将学生的个人信息显示出来

2. 右外连接

使用RIGHT JOIN,会完整显示右侧表 的所有行,左表无匹配的列置为NULL

典型场景:需要以右表为主体。比如"列出所有成绩,并显示对应的学生信息"。某个成绩如果找不到对应的学生(可能学生记录已被删除),成绩记录依然要呈现,学生信息为空。

例子:对stu表和exam表联合查询,把所有的成绩都显示出来,即使这个成绩没有学生与它对应,也要显示出来


四、如何选择左连接还是右连接

实际上,左连接和右连接在功能上可以互相转换,只需交换表的顺序。例如:

  • "列出所有部门和员工,包括没有员工的部门"

    可以写作:部门表 LEFT JOIN 员工表 (左表是部门,完整保留)。

    也可以写作:员工表 RIGHT JOIN 部门表(右表是部门,完整保留)。

开发建议 :通常固定使用LEFT JOIN会更好理解,把要全量保留的主表放在左边。


五、总结

  • 内连接 :结果集只包含匹配成功的行,两表地位平等,无主次之分。

  • 左外连接 :左表为主,左表所有行一定出现;右表有就显示,没有就为空。

  • 右外连接 :右表为主,右表所有行一定出现;左表有就显示,没有就为空。

如果把内连接想象成两个圆取交集,那么左外连接就像是保留左边整个圆,右边只取与左边相交的部分,未相交的右半部分留白

好啦,这就是关于MySQL的内外连接的知识点啦,下篇再见~~

相关推荐
qq_349317488 小时前
CSS如何实现全屏背景图固定_background-attachment fixed
jvm·数据库·python
qq_460978408 小时前
Go语言如何做环境变量配置_Go语言环境变量管理教程【详解】
jvm·数据库·python
PaperData8 小时前
1990-2024年全国地震空间分布数据(包含时间、震级、经度、纬度、深度)
数据库·数据分析·经管
一 乐8 小时前
茶叶商城|基于springboot + vue茶叶商城系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·茶叶商城系统
wuxinyan1238 小时前
大模型学习之路02:提示工程从入门到精通(第二篇)
人工智能·python·学习
HABuo10 小时前
【linux(四)】套接字编程--基于UDP协议的客户端服务端
linux·服务器·c++·网络协议·ubuntu·udp·centos
szccyw010 小时前
PHP源码能否用二手服务器部署_老旧服务器性价比分析【方法】
jvm·数据库·python
田超凡10 小时前
深入理解MySQL_8 索引Index(I)
mysql·java-ee
艾莉丝努力练剑10 小时前
【Linux网络】Linux 网络编程入门:UDP Socket 编程(下)
linux·运维·服务器·网络·计算机网络·安全·udp