LeetCode:Database 28.销售员

Posted Xiao Miao

tags:

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

要求:给定 3 个表: salesperson, company, orders,输出所有表 salesperson 中,没有向公司 ‘RED’ 销售任何东西的销售员。

salesperson表:

+----------+------+--------+-----------------+-----------+
| sales_id | name | salary | commission_rate | hire_date |
+----------+------+--------+-----------------+-----------+
|   1      | John | 100000 |     6           | 4/1/2006  |
|   2      | Amy  | 120000 |     5           | 5/1/2010  |
|   3      | Mark | 65000  |     12          | 12/25/2008|
|   4      | Pam  | 25000  |     25          | 1/1/2005  |
|   5      | Alex | 50000  |     10          | 2/3/2007  |
+----------+------+--------+-----------------+-----------+
表 salesperson 存储了所有销售员的信息。每个销售员都有一个销售员编号 sales_id 和他的名字 name 。

company表:

+---------+--------+------------+
| com_id  |  name  |    city    |
+---------+--------+------------+
|   1     |  RED   |   Boston   |
|   2     | ORANGE |   New York |
|   3     | YELLOW |   Boston   |
|   4     | GREEN  |   Austin   |
+---------+--------+------------+
表 company 存储了所有公司的信息。每个公司都有一个公司编号 com_id 和它的名字 name 。

orders表:

+----------+------------+---------+----------+--------+
| order_id | order_date | com_id  | sales_id | amount |
+----------+------------+---------+----------+--------+
| 1        |   1/1/2014 |    3    |    4     | 100000 |
| 2        |   2/1/2014 |    4    |    5     | 5000   |
| 3        |   3/1/2014 |    1    |    1     | 50000  |
| 4        |   4/1/2014 |    1    |    4     | 25000  |
+----------+----------+---------+----------+--------+
表 orders 存储了所有的销售数据,包括销售员编号 sales_id 和公司编号 com_id 。

分析:
1.先在company表中找到’RED’公司的编号,然后通过编号找到orders表中对应的sales_id
2.在salesperson表中找到不在这些sales_id中的sales_id对应的销售员的姓名

SQL语句:

select name 
from salesperson
where sales_id not in(
select o.sales_id
from orders o
join company c
on c.com_id=o.com_id
and c.name='RED');

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

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

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

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

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

LeetCode:Database 47.销售分析III

LeetCode:Database 91.按年度列出销售总额