六、SQL–表连接⑥(外部连接)

内部连接:要求组成连接的两个表必须具有匹配的记录,T_Order表中的数据如下:

FId FNumber FPrice FCustomerId FTypeId
1 K001 100.00 1 1
2 K002 200.00 1 1
3 T003 300.00 1 2
4 N002 100.00 2 2
5 N003 500.00 3 4
6 T001 300.00 4 3
7 T002 100.00 <NULL> 1

使用内部连接可以查询每张订单的订单号、价格、对应的客户姓名以及客户年龄,SQL语句如下:

SELECT o.FNumber,o.FPrice,o.FCustomerId,c.FName,c.FAge FROM T_Order o INNER JOIN T_Customer c ON o.FCustomerId=c.FId

执行结果:

FNumber FPrice FCustomerId FName FAge
K001 100.00 1 TOM 21
K002 200.00 1 TOM 21
T003 300.00 1 TOM 21
N002 100.00 2 MIKE 24
N003 500.00 3 JACK 30
T001 300.00 4 TOM 25

T_Order表中有7行数据,而通过以上内部连接查询得到的结果只有6条,其中订单号为T002的订单没有显示到结果集中。因为订单号为T002的订单的FCustomerId字段值为空,无法与T_Customer表中的任何行匹配,所以它没有显示到结果集中。

如果要求无法匹配的NULL值也要显示到结果集中,这种处理方式就无法满足要求。
如:查询每张订单的订单号、价格、对应的客户姓名以及客户年龄,如果没有对应的客户,则在客户信息处显示空格
希望的查询结果是如下:这就能通过外部连接来实现

FNumber FPrice FCustomerId FName FAge
K001 100.00 1 TOM 21
K002 200.00 1 TOM 21
T003 300.00 1 TOM 21
N002 100.00 2 MIKE 24
N003 500.00 3 JACK 30
T001 300.00 4 TOM 25
T002 100.00 <NULL> <NULL> <NULL>

外部连接:主要用来解决空值匹配问题。语法与内部连接几乎一样,主要区别就是对于空值的处理。
外部连接不需要两个表具有匹配记录,这样可以指定某个表中的记录总是放到结果集中。根据哪个表中的记录总是放到结果集中。

外部连接分为三种类型:

右外部连接(RIGHT OUTER JOIN)
左外部连接(LEFT OUTER JOIN)
全外部连接(FULLOUTER JOIN)。

三者的共同点是都返回符合连接条件的数据,这一点是和内部连接是一样的,不同点在于它们对不符合连接条件的数据处理,三者不同点说明如下:

1,左外部连接还返回左表中不符合连接条件的数据
2,左外部连接还返回右表中不符合连接条件的数据
3,全外部连接还返回左表中不符合连接条件的数据以及右表中不符合连接条件的数据,它其实是左外部连接和左外部连接的合集。

左表和右表是相对于JOIN关键字来说的,位于JOIN关键字左侧的表即被称为左表,而位于JOIN关键字右侧的表即被称为右表。如:

SELECT o.FNumber,o.FPrice,o.FCustomerId,
c.FName,c.FAge FROM T_Order o INNER JOIN T_Customer c ON o.FCustomerId=c.FId

这里的T_Order就是左表,而T_Customer则是右表。

左外部连接

左表中所有的记录都会被放到结果集中,无论是否在右表中存在匹配记录。
如:查询每张订单的订单号、价格、对应的客户姓名以及客户年龄,如果没有对应的客户,则在客户信息处显示空格

SELECT o.FNumber,o.FPrice,o.FCustomerId,
c.FName,c.FAge FROM T_Order o LEFT OUTER JOIN T_Customer c ON o.FCustomerId=c.FId

执行结果:

FNumber FPrice FCustomerId FName FAge
K001 100.00 1 TOM 21
K002 200.00 1 TOM 21
T003 300.00 1 TOM 21
N002 100.00 2 MIKE 24
N003 500.00 3 JACK 30
T001 300.00 4 TOM 25
T002 100.00 <NULL> <NULL> <NULL>

WHERE语句会改变左连接最终的结果集。
如:为上面的SQL语句添加一个WHERE子句,使得结果中不包含价格小于150元的订单:

SELECT o.FNumber,o.FPrice,o.FCustomerId,
c.FName,c.FAge FROM T_Order o LEFT OUTER JOIN T_Customer c ON o.FCustomerId=c.FId WHERE o.FPrice>=150

执行结果:

FNumber FPrice FCustomerId FName FAge
K002 200.00 1 TOM 21
T003 300.00 1 TOM 21
N003 500.00 3 JACK 30
T001 300.00 4 TOM 25

右外部连接

不管是否成功匹配连接条件都会返回右表中的所有记录。
如:使用右外部连接查询每张订单的信息以及对应的客户信息:

SELECT o.FNumber,o.FPrice,o.FCustomerId,c.FName,c.FAge
 FROM T_Order o RIGHT OUTER JOIN T_Customer c ON o.FCustomerId=c.FId

执行结果:

FNumber FPrice FCustomerId FName FAge
K001 100.00 1 TOM 21
K002 200.00 1 TOM 21
T003 300.00 1 TOM 21
N002 100.00 2 MIKE 24
N003 500.00 3 JACK 30
T001 300.00 4 TOM 25
<NULL> <NULL> <NULL> LINDA <NULL>

可以看到前6条记录都是符合连接条件的,而T_Customer表中姓名为LINDA的客户没有对应的订单,但是仍然被放到了结果集中,其无法匹配的字段填充的都是NULL。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

媛媛要加油呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值