美文网首页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–表连接⑥(外部连接)

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