MySQL - 左连接、右连接、内连接、完全外连接、交叉连接 & 一对多、多对一、多对多 & 联合连接

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 介绍MySQL中不同类型的SQL连接操作,包括左连接、右连接、内连接、完全外连接、交叉连接,以及数据库关系中的一对多、多对一、多对多和联合连接的概念和使用场景。

前言

做服务端接口开发时,经常对数据库进行查询操作,了解并掌握数据库的左连接、右连接、内连接、完全外连接、交叉连接,一对多、多对一、多对多,联合连接等概念和使用就很重要了。

首先给出两个数据表,分别为学生表和课程表,假设一个学生只能选一门课程。

表1:Student
-------------
| ID | Name |
-------------
| 1  | 阿猫 |
| 2  | 阿狗 |
| 3  | 阿猪 |
-------------

表2:Course
-------------
| ID | Cname|
-------------
| 1  | 篮球 |
| 2  | 足球 |
| 4  | 排球 |
-------------

一、外连接(左外连接、右外连接、完全外连接)

1.左外连接,简称左连接

语法:left join 或 left outer join
语句:

select * 
from student
left join course on student.ID=course.ID

特点:取两表交集且并保留左表
结果:

--------------------------
| ID | Name | ID | Cname |
--------------------------
| 1  | 阿猫 | 1  | 篮球 |
| 2  | 阿狗 | 2  | 足球 |
| 3  | 阿猪 |NULL| NULL |
--------------------------

2.右外连接,简称右连接

语法:right join 或 right outer join
语句:

select * 
from student
right join course on student.ID=course.ID

特点:取两表交集且并保留右表
结果:

--------------------------
| ID | Name | ID | Cname |
--------------------------
| 1  | 阿猫 | 1  | 篮球 |
| 2  | 阿狗 | 2  | 足球 |
|NULL| NULL | 4  | 排球 |
--------------------------

3.完全外连接,简称全连接

语法:full join 或 full outer join
语句:

select * 
from student
full join course on student.ID=course.ID

特点:包含左右两表中所有的行
结果:

--------------------------
| ID | Name | ID | Cname |
--------------------------
| 1  | 阿猫 | 1  | 篮球 |
| 2  | 阿狗 | 2  | 足球 |
| 3  | 阿猪 |NULL| NULL |
|NULL| NULL | 4  | 排球 |
--------------------------

二、内连接

1.内连接

语法:join 或 inner join
语句:

select * 
from student 
inner join course on student.ID=course.ID

特点:显示两张表所有记录一一对应,没有对应上的将会被过滤
结果:

--------------------------
| ID | Name | ID | Cname |
--------------------------
| 1  | 阿猫 | 1  | 篮球 |
| 2  | 阿狗 | 2  | 足球 |
--------------------------

三、交叉连接

1.交叉连接

语法:cross join
语句:

select * 
from student 
cross join course

特点:对两个或者多个表进行笛卡儿积操作
结果:

--------------------------
| ID | Name | ID | Cname |
--------------------------
| 1  | 阿猫 | 1  | 篮球 |
| 2  | 阿狗 | 1  | 篮球 |
| 3  | 阿猪 | 1  | 篮球 |
| 1  | 阿猫 | 2  | 足球 |
| 2  | 阿狗 | 2  | 足球 |
| 3  | 阿猪 | 2  | 足球 |
| 1  | 阿猫 | 4  | 排球 |
| 2  | 阿狗 | 4  | 排球 |
| 3  | 阿猪 | 4  | 排球 |
--------------------------

技巧:如果我们在此时给这条语句加上`where`子句的时候,比如【select * from student cross join course where student.ID = course.ID】,结果和inner join所示执行结果一样

四、联合连接

1.联合连接

语法:union 或 union all
语句:

select ... from table1
union
select ... from table2

特点:两个或多个的表,相同字段合并起来

五、一对多、多对一、多对多

疑问:当然上面两表为一对一关系,那么如果表A和表B为一对多、多对一或多对多的时候,我们又该如何写连接SQL语句呢?
解答:其实两表一对多的SQL语句和一对一的SQL语句的写法都差不多,只是查询的结果不一样,当然两表也要略有改动。

---------------------
|      student      |
---------------------
| Sno | Name | Cno |
---------------------

-------------------
|     classes     |
-------------------
|  Cno  |  CName  |

1.一对多

场景:一个班级可以有多个学生
语句:

select * from classes where Cno = 1;

结果: 查询班级为一班的所有学生

2.多对一

场景:多个学生属于某个班级
语句:

select c.CName 
FROM classes as c
JOIN student as s ON s.Cno = c.Cno 
WHERE s.Name in ('小明', '小花', '小白', '小红');

结果: 查询这几个学生所在的班级的名称

3.多对多

场景:一个学生可以选择多门课程,一门课程可以被多个学生选择,因此学生表student和课程表course之间是多对多的关系
技巧:当两表为多对多关系的时候,我们需要建立一个中间表student_course,中间表至少要有两表的主键,当然还可以有别的内容

---------------
|   student   |
---------------
| Sno | Name |
---------------

----------------
|    course    |
----------------
| Cno | Cname |
----------------

--------------
|     SC     |
--------------
| Sno | Cno |
--------------

语句:

select
    s.Name, c.Cname 
from student_course as sc 
left join student as s on s.Sno = sc.Sno 
left join course as c on c.Cno = sc.Cno

结果: 查询每个学生的姓名,以及所在的班级的名称

六、说明

(1)在MySQL数据库中,left join、right join、full join、inner join的执行速度是怎样的?
答:left join、right join、full join、inner join的执行速度取决于多个因素,包括表的大小、索引的使用情况、查询条件等等。一般来说,inner join的执行速度最快,因为它只返回两个表中匹配的行,而不返回任何不匹配的行。left join和right join的执行速度通常比inner join慢一些,因为它们需要返回匹配和不匹配的行。full join的执行速度通常是最慢的,因为它需要返回两个表中所有的行。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
10天前
|
关系型数据库 MySQL 数据库连接
Unity连接Mysql数据库 增 删 改 查
在 Unity 中连接 MySQL 数据库,需使用 MySQL Connector/NET 作为数据库连接驱动,通过提供服务器地址、端口、用户名和密码等信息建立 TCP/IP 连接。代码示例展示了如何创建连接对象并执行增删改查操作,确保数据交互的实现。测试代码中,通过 `MySqlConnection` 类连接数据库,并使用 `MySqlCommand` 执行 SQL 语句,实现数据的查询、插入、删除和更新功能。
|
24天前
|
关系型数据库 MySQL 数据库连接
数据库连接工具连接mysql提示:“Host ‘172.23.0.1‘ is not allowed to connect to this MySQL server“
docker-compose部署mysql8服务后,连接时提示不允许连接问题解决
|
2天前
|
关系型数据库 MySQL 网络安全
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
40 25
|
3月前
|
关系型数据库 MySQL 网络安全
DBeaver连接MySQL提示Access denied for user ‘‘@‘ip‘ (using password: YES)
“Access denied for user ''@'ip' (using password: YES)”错误通常与MySQL用户权限配置或网络设置有关。通过检查并正确配置用户名和密码、用户权限、MySQL配置文件及防火墙设置,可以有效解决此问题。希望本文能帮助您成功连接MySQL数据库。
327 4
|
3月前
|
安全 关系型数据库 MySQL
【赵渝强老师】MySQL的连接方式
本文介绍了MySQL数据库服务器启动后的三种连接方式:本地连接、远程连接和安全连接。详细步骤包括使用root用户登录、修改密码、创建新用户、授权及配置SSL等。并附有视频讲解,帮助读者更好地理解和操作。
529 1
|
3月前
|
NoSQL 安全 关系型数据库
2024Mysql And Redis基础与进阶操作系列(6)作者——LJS[含MySQL 多表之一对一/多;多对多;多表联合查询等详解步骤及常见报错问题所对应的解决方法]
MySQL 多表之一对一/多;多对多;多表联合之交叉连接;内连接;左、右、外、满、连接;子查询及关键字;自连接查询等详解步骤及常见报错问题所对应的解决方法
|
4月前
|
SQL Java 关系型数据库
java连接mysql查询数据(基础版,无框架)
【10月更文挑战第12天】该示例展示了如何使用Java通过JDBC连接MySQL数据库并查询数据。首先在项目中引入`mysql-connector-java`依赖,然后通过`JdbcUtil`类中的`main`方法实现数据库连接、执行SQL查询及结果处理,最后关闭相关资源。
402 6
|
11天前
|
关系型数据库 MySQL 数据库
Docker Compose V2 安装常用数据库MySQL+Mongo
以上内容涵盖了使用 Docker Compose 安装和管理 MySQL 和 MongoDB 的详细步骤,希望对您有所帮助。
87 42
|
29天前
|
缓存 关系型数据库 MySQL
【深入了解MySQL】优化查询性能与数据库设计的深度总结
本文详细介绍了MySQL查询优化和数据库设计技巧,涵盖基础优化、高级技巧及性能监控。
242 0
|
2月前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
73 3

推荐镜像

更多