LeetCode:Database 46.销售分析 II

Posted Xiao Miao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode:Database 46.销售分析 II相关的知识,希望对你有一定的参考价值。

要求·:编写一个 SQL 查询,查询购买了 S8 手机却没有购买 iPhone 的买家。注意这里 S8 和 iPhone 是 Product 表中的产品。

Product 表的结构:

+--------------+---------+
| Column Name  | Type    |
+--------------+---------+
| product_id   | int     |
| product_name | varchar |
| unit_price   | int     |
+--------------+---------+
product_id 是这张表的主键

Sales 表的结构:

+-------------+---------+
| Column Name | Type    |
+-------------+---------+
| seller_id   | int     |
| product_id  | int     |
| buyer_id    | int     |
| sale_date   | date    |
| quantity    | int     |
| price       | int     |
+------ ------+---------+
这个表没有主键,它可以有重复的行.
product_id 是 Product 表的外键.

Product 表:

+------------+--------------+------------+
| product_id | product_name | unit_price |
+------------+--------------+------------+
| 1          | S8           | 1000       |
| 2          | G4           | 800        |
| 3          | iPhone       | 1400       |
+------------+--------------+------------+

Sales 表:

+-----------+------------+----------+------------+----------+-------+
| seller_id | product_id | buyer_id | sale_date  | quantity | price |
+-----------+------------+----------+------------+----------+-------+
| 1         | 1          | 1        | 2019-01-21 | 2        | 2000  |
| 1         | 2          | 2        | 2019-02-17 | 1        | 800   |
| 2         | 1          | 3        | 2019-06-02 | 1        | 800   |
| 3         | 3          | 3        | 2019-05-13 | 2        | 2800  |
+-----------+------------+----------+------------+----------+-------+

Result Table:

+-------------+
| buyer_id    |
+-------------+
| 1           |
+-------------+
id 为 1 的买家购买了一部 S8,但是却没有购买 iPhone,而 id 为 3 的买家却同时购买了这 2 部手机。

SQL语句:

select distinct buyer_id
from sales
where buyer_id
not in (select a.buyer_id
from sales a
join product b
on b.product_name='iphone'  and a.product_id=b.product_id
) and buyer_id in(select a.buyer_id
from sales a
join product b
on b.product_name='s8'  and a.product_id=b.product_id);

以上是关于LeetCode:Database 46.销售分析 II的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode:Database 40.产品销售分析 II

LeetCode:Database 41.产品销售分析 III

LeetCode:Database 47.销售分析III

LeetCode:Database 39.产品销售分析 I

LeetCode:Database 28.销售员

LeetCode:Database 104.按日期分组销售产品