同时左连接多张表_图解SQL联结:左联结

今天我们用下面的表来学习左联结。其中,

学生表(student):用来记录学生的基本信息

成绩表(score):用来记录学生选修课程的成绩

c964a18a1cf3d01e5c52deda031048ac.png

1.什么是左联结?

左联结,会将左侧表中的数据全部取出来。下面图片中用文氏图画出了左联结,是红颜色的部分。

753f21096f912bfe38a6bace248f4c1e.png

2.左联结是如何运行的?

下图是左联结的运行过程:

db5493c5a4142e8099f3075c3314b751.png

第1步,取出符合条件的行

两个表通过学号进行左联结,会将左侧的表作为主表,主表中的数据全部取出来,也就是将学生表里的数据全部取出来。

右边的表只选出和左边表相同学号的行,也就是学号0001所在的两行数据。

第2步,将两个表里取出的数据合并,如何合并呢?

这里就是进行交叉联结了。因为学号0002在右边的表里没有对应的行,所以这一行对应列的值是空值(Null)

3.左联结sql语句怎么写?

在图片里我加上了左联结对应的sql语句:

cbacab96f41709724f88a717e1616c58.png

我们来看这个sql语句的3个关键地方:

1)第1个关键地方是在from子句

之前的from子句中只有1张表,而现在我们在from子句中同时使用了2张表。

由于表名太长,会影响sql的可读性,所以这里使用as对每个表起了别名,方便使用。在sql语句中我们给学生表起了别名叫做a,给成绩表起了别名叫做b。

在使用到列名的时候,为了方便区分这个列是哪个表的,所以会在列名前面加上表名.,所以你会看到在selec子句里的列名前面都加了表名。

因为这里select子句只查找出学号,姓名,课程号,所以最终查询结果是虚框里面的列。

2)第2个关键地方是from子句中用left join将两个表联结起来。

这里的left join就表示联结方式是左联结,选取出同时存在于两张表中的数据。

3)第3个关键地方是from子句中的关键字on后面的表示两个表通过哪个列匹配产生关系的,这里写的on a.学号=b.学号,表示两个表通过学号关联起来。

4.左联结变种

在左联结的基础上,我们再看一个问题,图片中红色部分的地方如何用sql表示呢?

607a059de1caad99a54bb913bc86ce1a.png

这是在左联结的基础上去掉了,两个表中共同的地方,也就是去掉了两个圆圈的公共部分。

我们在刚才左联结的sql语句中,加入一个where子句 里面的条件是右边表的学号为空值。这样就选出了左边表,但是不属于两个表公共部分的数据,也就是图片中圆圈红色的部分:

4dd88ca24297412aff61febfb6e0496a.png

你开将前面学过的联结在草稿纸上画出来,亲自理解下整个过程

d1e63b811f72f2496ac2a7ec2508626e.png

推荐:如何提升你的分析技能,实现升职加薪?

7be2f95483a8dfb711fbef84d381d23d.png
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值