上节课给大家介绍了MySQL子查询的基本内容,具体可回顾MySQL子查询的基本使用方法(四),本节课我们准备给大家介绍MySQL的多表联合查询。大家都知道,MySQL多表联合查询包括内连接、外连接、笛卡尔积连接查询三种。今天我们先重点介绍常用的外连接与内连接查询,即left join /right join/inner join的基本用法。
常见的两表连接查询的基本语法结构如下:
select 表名.字段名,表名.字段名,表名.字段名,...
from 左表表名 (as)左表别名
left/right/inner join 右表表名 (as) 右表别名
on 左表.连接字段=右表.连接字段
where 查询条件;
01
左连接left (outer) join
左连接的定义:左连接全称为左外连接,是外连接的一种。它是以左表为基础,根据ON后给出的连接条件将两表连接起来。结果会将左表所有的记录列出,而右表只列出ON后与左表满足条件的部分。
为了更好地让大家理解,我们还是分别举栗子说明~先回顾一下上节课的titanic表与phone表的基本数据情况。
【titanic乘客基本信息表】
【phone手机品牌表】
【任务1】我们想找出使用华为手机的乘客编号、姓名、性别、年龄和手机品牌。可以使用以下左连接查询实现。
SELECT a.PassengerId,a.name,b.sex,b.age,a.phonebrand
from phone a
left join titanic b
on a.PassengerId=b.passengerId
where a.phonebrand="HUAWEI";
查询结果如下:
可以看到,查询结果把左表phone符合华为手机条件的所有查询结果都列出来了,而右表titanic只列出了与左表满足ON连接条件的部分结果(中间两列),其他不符合连接条件的结果均为NULL。
02
右连接right (outer) join
右连接的定义:右连接全称为右外连接,也是外连接的一种。与左连接刚好相反,它是以右表为基础,根据ON后给出的连接条件将两表连接起来。结果会将右表所有的记录列出,而左表只列出ON后与右表满足条件的部分。
【任务2】查找船舱等级为3且存活的乘客编号、姓名、是否存活、船舱等级和手机品牌,可以通过以下右连接查询实现。
SELECT a.passengerId,a.name,b.survived,b.pclass,a.phonebrand
from phone a
right join titanic b
on a.PassengerId=b.passengerId
where b.survived=1
and b.pclass=3;
可以看到,查询结果把右表titanic符合生存且船舱等级为3的条件的乘客都列出来了,而左表phone只列出了与右表满足ON连接条件的部分结果,其他不符合连接条件的结果均为NULL。
03
内连接inner join
内连接是一种一一映射关系,即左右两张表都同时存在的记录才能显示出来,用韦恩图表示是两个集合的交集。
【任务3】查找使用苹果手机并且年龄大于30岁的男性乘客,展示乘客编号,姓名,性别,年龄信息。可以通过以下内连接查询语句实现。
SELECT a.passengerId,a.name,b.sex,b.age
from phone a
inner join titanic b
on a.PassengerId=b.passengerId
where a.phonebrand="iPhone"
and b.age>30
and b.sex="male";
可以看出,内连接将同时符合查询条件(使用苹果手机并且年龄大于30岁的男性乘客),符合ON连接条件且同时存在于左右两张表的记录都展示出来了,也就是求符合查询条件的左右两张表的交集。
注意:
04
总结
以上就是本节课要介绍的全部内容,下节课我们将继续介绍多表联合查询的其他内容以及多表联合查询与子查询的联系与区别,敬请关注!
想学习更多数据分析、数据挖掘干货内容,欢迎关注公众号