comments | difficulty | edit_url | tags | |
---|---|---|---|---|
true |
简单 |
|
表: Customer
+---------------+---------+ | Column Name | Type | +---------------+---------+ | customer_id | int | | customer_name | varchar | +---------------+---------+ customer_id 是该表具有唯一值的列。 该表的每行包含网上商城的每一位顾客的信息。
表: Orders
+---------------+---------+ | Column Name | Type | +---------------+---------+ | order_id | int | | sale_date | date | | order_cost | int | | customer_id | int | | seller_id | int | +---------------+---------+ order_id 是该表具有唯一值的列。 该表的每行包含网上商城的所有订单的信息. sale_date 是顾客 customer_id 和卖家 seller_id 之间交易的日期.
表: Seller
+---------------+---------+ | Column Name | Type | +---------------+---------+ | seller_id | int | | seller_name | varchar | +---------------+---------+ seller_id 是该表主具有唯一值的列。 该表的每行包含每一位卖家的信息.
写一个解决方案, 报告所有在 2020
年度没有任何卖出的卖家的名字。
返回结果按照 seller_name
升序排列。
查询结果格式如下例所示。
示例 1:
输入: Customer
表: +--------------+---------------+ | customer_id | customer_name | +--------------+---------------+ | 101 | Alice | | 102 | Bob | | 103 | Charlie | +--------------+---------------+Orders
表: +-------------+------------+--------------+-------------+-------------+ | order_id | sale_date | order_cost | customer_id | seller_id | +-------------+------------+--------------+-------------+-------------+ | 1 | 2020-03-01 | 1500 | 101 | 1 | | 2 | 2020-05-25 | 2400 | 102 | 2 | | 3 | 2019-05-25 | 800 | 101 | 3 | | 4 | 2020-09-13 | 1000 | 103 | 2 | | 5 | 2019-02-11 | 700 | 101 | 2 | +-------------+------------+--------------+-------------+-------------+Seller
表: +-------------+-------------+ | seller_id | seller_name | +-------------+-------------+ | 1 | Daniel | | 2 | Elizabeth | | 3 | Frank | +-------------+-------------+输出:
+-------------+ |seller_name
| +-------------+ | Frank | +-------------+解释:
Daniel 在 2020 年 3 月卖出 1 次。 Elizabeth 在 2020 年卖出 2 次, 在 2019 年卖出 1 次。 Frank 在 2019 年卖出 1 次, 在 2020 年没有卖出。
我们可以使用左连接,将 Seller
表与 Orders
表按照字段 seller_id
连接,然后按照 seller_id
分组,统计每个卖家在
# Write your MySQL query statement below
SELECT seller_name
FROM
Seller
LEFT JOIN Orders USING (seller_id)
GROUP BY seller_id
HAVING IFNULL(SUM(YEAR(sale_date) = 2020), 0) = 0
ORDER BY 1;