《SQL必知必会第五版》第十三章(创建高级联结)挑战题

本文介绍了如何使用SQL的INNERJOIN和LEFTOUTERJOIN操作,分别从Customers和Orders表中检索订单信息,以及从Products和OrderItems表中获取产品与订单关联的数据,并展示了如何计算供应商的产品数量,包括未售出产品。
摘要由CSDN通过智能技术生成
1. 使用 INNER JOIN 编写 SQL 语句,以检索每个顾客的名称( Customers表中的cust_name 和所有的订单号( Orders 表中的 order_num )。
--WHERE子句联结两表
SELECT cust_name,order_num
FROM Customers,Orders
WHERE Customers.cust_id = Orders.cust_id
ORDER BY cust_name;
--INNER JOIN 联结
SELECT cust_name,order_num
FROM Customers
INNER JOIN Orders ON Customers.cust_id = Orders.cust_id
ORDER BY cust_name;

2. 修改刚刚创建的 SQL 语句,仅列出所有顾客,即使他们没有下过订单。

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 )的列表,并按商品名称排序。
SELECT prod_name, order_num
FROM Products 
LEFT OUTER JOIN OrderItems ON Products.prod_id = OrderItems.prod_id
ORDER BY prod_name;
4. 修改上一题中创建的 SQL 语句,使其返回每一项产品的总订单数 (不是订单号)。
SELECT prod_name, COUNT(order_num) AS num_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 JOIN COUNT() 聚合函数来计算 Products 表中每种产品的数量。注意: vend_id 列 会显示在多个表中,因此在每次引用它时都需要完全限定它。
SELECT Vendors.vend_id, COUNT(prod_id) AS num_pro
FROM Vendors
LEFT OUTER JOIN Products ON Vendors.vend_id = Products.vend_id
GROUP BY Vendors.vend_id;
  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值