SQL外联结

SQL外联结,许多联结将一个表中的行与另一个表中的行相关联,但有时候需要包含没有关联行的那些行。例如,可能需要使用联结完成以下工作:

  • 对每个顾客下的订单进行计数,包括那些至今尚未下订单的顾客;
  • 列出所有产品以及订购数量,包括没有人订购的产品;
  • 计算平均销售规模,包括那些至今尚未下订单的顾客。

在上述例子中,联结包含了那些在相关表中没有关联行的行。这种联结称为外联结。

注意:语法差别
需要注意,用来创建外联结的语法在不同的SQL实现中可能稍有不同。

下面的SELECT语句给出了一个简单的内联结。它检索所有顾客及其订单:

    SELECT Customers.cust_id, Orders.order_num
    FROM Customers
      INNER JOIN Orders ON Customers.cust_id = Orders.cust_id;

外联结语法类似。要检索包括没有订单顾客在内的所有顾客,可如下进行:

    SELECT Customers.cust_id, Orders.order_num
    FROM Customers
      LEFT OUTER JOIN Orders ON Customers.cust_id = Orders.cust_id;

输出结果如下:

    cust_id          order_num
    ----------      ---------
    1000000001      20005
    1000000001      20009
    1000000002      NULL
    1000000003      20006
    1000000004      20007
    1000000005      20008

类似前面提到的内联结,这条SELECT语句使用了关键字OUTER JOIN来指定联结类型(而不是在WHERE子句中指定)。但是,与内联结关联两个表中的行不同的是,外联结还包括没有关联行的行。在使用OUTER JOIN语法时,必须使用RIGHT或LEFT关键字指定包括其所有行的表(RIGHT指出的是OUTER JOIN右边的表,而LEFT指出的是OUTER JOIN左边的表)。上面的例子使用LEFT OUTER JOIN从FROM子句左边的表(Customers表)中选择所有行。为了从右边的表中选择所有行,需要使用RIGHT OUTER JOIN,如下例所示:

    SELECT Customers.cust_id, Orders.order_num
    FROM Customers
      RIGHT OUTER JOIN Orders ON Customers.cust_id = Orders.cust_id;

注意:SQLite外联结
SQLite支持LEFT OUTER JOIN,但不支持RIGHT OUTER JOIN。幸好,如果你确实需要在SQLite中使用RIGHT OUTER JOIN,有一种更简单的办法,这将在下面的提示中介绍。

提示:外联结的类型
要记住,总是有两种基本的外联结形式:左外联结和右外联结。它们之间的唯一差别是所关联的表的顺序。换句话说,调整FROM或WHERE子句中表的顺序,左外联结可以转换为右外联结。因此,这两种外联结可以互换使用,哪个方便就用哪个。

还存在另一种外联结,就是全外联结(full outer join),它检索两个表中的所有行并关联那些可以关联的行。与左外联结或右外联结包含一个表的不关联的行不同,全外联结包含两个表的不关联的行。全外联结的语法如下:

    SELECT Customers.cust_id, Orders.order_num
    FROM Customers
      FULL OUTER JOIN Orders ON Customers.cust_id = Orders.cust_id;

注意:FULL OUTER JOIN的支持
MariaDB、MySQL和SQLite不支持FULL OUTER JOIN语法。

酷客网相关文章:

赞(0)

评论 抢沙发

评论前必须登录!

 

SQL教程