博客
关于我
LeetCode:Database 28.销售员
阅读量:684 次
发布时间:2019-03-17

本文共 1758 字,大约阅读时间需要 5 分钟。

要求:给定 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 salespersonwhere sales_id not in(select o.sales_idfrom orders ojoin company con c.com_id=o.com_idand c.name='RED');

转载地址:http://ernhz.baihongyu.com/

你可能感兴趣的文章
Mysql学习总结(59)——数据库分库分表策略总结
查看>>
Mysql学习总结(60)——并发量大、数据量大的互联网业务数据库设计规范总结
查看>>
Mysql学习总结(61)——MySQL优化之DBA级优化整理汇总
查看>>
Mysql学习总结(64)——Mysql配置文件my.cnf各项参数解读
查看>>
Mysql学习总结(65)——项目实战中常用SQL实践总结
查看>>
Mysql学习总结(66)——设置MYSQL数据库编码为UTF-8
查看>>
Mysql学习总结(68)——MYSQL统计每天、每周、每月、每年数据 SQL 总结
查看>>
Mysql学习总结(69)——Mysql EXPLAIN 命令使用总结
查看>>
Mysql学习总结(6)——MySql之ALTER命令用法详细解读
查看>>
Mysql学习总结(70)——MySQL 优化实施方案
查看>>
Mysql学习总结(71)——MySQL 重复记录查询与删除总结
查看>>
Mysql学习总结(73)——MySQL 查询A表存在B表不存在的数据SQL总结
查看>>
Mysql学习总结(77)——温故Mysql数据库开发核心原则与规范
查看>>
Mysql学习总结(78)——MySQL各版本差异整理
查看>>
Mysql学习总结(79)——MySQL常用函数总结
查看>>
Mysql学习总结(7)——MySql索引原理与使用大全
查看>>
Mysql学习总结(80)——统计数据库的总记录数和库中各个表的数据量
查看>>
Mysql学习总结(81)——为什么MySQL不推荐使用uuid或者雪花id作为主键?
查看>>
Mysql学习总结(82)——MySQL逻辑删除与数据库唯一性约束如何解决?
查看>>
Mysql学习总结(83)——常用的几种分布式锁:ZK分布式锁、Redis分布式锁、数据库分布式锁、基于JDK的分布式锁方案对比总结
查看>>