SQL 入门教程:高级联结(JOIN)练习题

本文内容

  1. 使用 INNER JOIN 编写 SQL 语句,以检索每个顾客的名称(Customers 表中的 cust_name)和所有的订单号(Orders 表中的 order_num)。

    1
    2
    3
    4
    
    SELECT cust_name, order_num 
    FROM Customers 
    JOIN Orders ON Customers.cust_id = Orders.cust_id 
    ORDER BY cust_name;
    
  2. 修改刚刚创建的 SQL 语句,仅列出所有顾客,即使他们没有下过订单。

    1
    2
    3
    4
    
    SELECT cust_name, order_num 
    FROM Customers 
    LEFT OUTER JOIN Orders ON Customers.cust_id = Orders.cust_id 
    ORDER BY cust_name;
    
  3. 使用 OUTER JOIN 联结 Products 表和 OrderItems 表,返回产品名称(prod_name)和与之相关的订单号(order_num)的列表,并按商品名称排序。

    1
    2
    3
    4
    
    SELECT prod_name, order_num 
    FROM Products LEFT OUTER JOIN OrderItems 
    ON Products.prod_id = OrderItems.prod_id 
    ORDER BY prod_name;
    
  4. 修改上一题中创建的 SQL 语句,使其返回每一项产品的总订单数(不是订单号)。

    1
    2
    3
    4
    5
    
    SELECT prod_name, COUNT(order_num) AS orders 
    FROM Products LEFT OUTER JOIN OrderItems 
    ON Products.prod_id = OrderItems.prod_id 
    GROUP BY prod_name 
    ORDER BY prod_name;
    
  5. 编写 SQL 语句,列出供应商(Vendors 表中的 vend_id)及其可供产品的数量,包括没有产品的供应商。你需要使用 OUTER JOINCOUNT() 聚合函数来计算 Products 表中每种产品的数量。注意:vend_id 列会显示在多个表中,因此在每次引用它时都需要完全限定它。

    1
    2
    3
    4
    
    SELECT Vendors.vend_id, COUNT(prod_id) 
    FROM Vendors 
    LEFT OUTER JOIN Products ON Vendors.vend_id = Products.vend_id 
    GROUP BY Vendors.vend_id;
    

请参阅

(完)

comments powered by Disqus

本文内容