美文网首页Oracle数据库管理之道
六、SQL–表连接⑥(外部连接)

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

作者: 小小一颗卤蛋 | 来源:发表于2020-05-07 19:02 被阅读0次

内部连接:要求组成连接的两个表必须具有匹配的记录,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。

相关文章

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

    内部连接:要求组成连接的两个表必须具有匹配的记录,T_Order表中的数据如下: 使用内部连接可以查询每张订单的订...

  • 六、SQL–表连接⑦(全外部连接)

    全外部连接并不是所有数据库系统都支持,最常使用的MYSQL就不支持全外部连接。 全外部连接:是左外部连接和右外部连...

  • 六、SQL–表连接④(交叉连接)

    交叉连接 与内连接比起来,交叉连接非常简单,因为它不存在ON子句。交叉连接会将涉及到的所有表中的所有记录都包含在结...

  • 六、SQL–表连接②(内连接)

    inner join: 内连接组合两张表,并且基于两张表中的关联关系来连接它们。使用内连接需要指定表中哪些字段组成...

  • 六、SQL–表连接⑤(自连接)

    自连接:参与连接的表为同一张表,即与自身连接。交叉连接、内连接、外连接等连接方式中只要参与连接的表是同一张表,那么...

  • 2020-04-01

    连接两表 SOLUTION 输入 输出 解题思路SQL 连接类型SQL 中有多种不同的连接: 内连接(INNER ...

  • SQL常见面试题

    1、SQL的表连接方式有哪些?SQL中连接按结果集分为:内连接,外连接,交叉连接内连接:inner join on...

  • 连表查询:sql1992和sql1999

    sql1992 sql分类 1.笛卡尔积 (表乘表) 2.等值连接 表的连接条件使用“=” 3.非等值连接 表的连...

  • 六、SQL–表连接③(不等值连接)

    等值连接: 连接的ON子句的条件包含一个等号运算。等值连接是最常用的连接,因为它指定的连接条件是一个表中的一个字段...

  • 六、SQL–表连接①(简介)

    表连接:进行多表检索最常用的技术,使用JOIN关键字将一个或者多个表按照彼此间的关系连接为一个结果集。数据准备:创...

网友评论

    本文标题:六、SQL–表连接⑥(外部连接)

    本文链接:https://www.haomeiwen.com/subject/oukzghtx.html