力扣1083-销售分析II

表: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 表的外键(reference 列)。
buyer_id 永远不会是 NULL。
sale_date 永远不会是 NULL。
该表的每一行都包含一次销售的一些信息。

编写一个解决方案,报告那些买了 S8 而没有买 iPhone买家 。注意,S8iPhoneProduct 表中显示的产品。

任意顺序 返回结果表。

结果格式如下所示。

示例 1:

复制代码
输入:
Product table:
+------------+--------------+------------+
| product_id | product_name | unit_price |
+------------+--------------+------------+
| 1          | S8           | 1000       |
| 2          | G4           | 800        |
| 3          | iPhone       | 1400       |
+------------+--------------+------------+
Sales table:
+-----------+------------+----------+------------+----------+-------+
| 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  |
+-----------+------------+----------+------------+----------+-------+
输出:
+-------------+
| buyer_id    |
+-------------+
| 1           |
+-------------+
解释:
id 为 1 的买家购买了一部 S8,但是却没有购买 iPhone,而 id 为 3 的买家却同时购买了这 2 部手机。

思路:

1、首先两个表关联;

2、case when 判断是否有卖S8和iPhone,有为1 否则为0

3、根据题目要求,"买了 S8 而没有买 iPhone买家",所以sum(S8)>0 ,sum(iPhone)=0;

代码:

sql 复制代码
select 
buyer_id 
from product t1
join sales t2 on t1.product_id= t2.product_id
group by buyer_id
having sum(case when product_name = 'S8'then 1 else 0 end) > 0 
   and sum(case when product_name = 'iPhone' then 1 else 0 end) = 0
;
相关推荐
深藏bIue2 小时前
Oracle修改完sga、pga启动失败处理方案
数据库·oracle
尋有緣2 小时前
力扣574-当选者
leetcode·oracle·数据库开发
程序员-King.2 小时前
day110—同向双指针(数组)—最多K个重复元素的最长子数组(LeetCode-2958)
算法·leetcode·双指针
做怪小疯子2 小时前
LeetCode 热题 100——二叉树——二叉树的右视图
算法·leetcode·职场和发展
Swift社区2 小时前
LeetCode 442 - 数组中重复的数据
算法·leetcode·职场和发展
努力学算法的蒟蒻2 小时前
day25(12.5)——leetcode面试经典150
算法·leetcode·职场和发展
他们叫我技术总监2 小时前
ORA-14402: 更新分区关键字列将导致分区的更改,多种解决方案
oracle·ora-14402
步步为营DotNet3 小时前
深度解析DbContext ChangeTracker:实体状态管理与性能优化
数据库·oracle·性能优化
a3722107743 小时前
HikariCP配置 高并发下连接泄漏避免
java·数据库·oracle