Leetcode_1159. 市场分析 II

本文介绍了一个SQL查询挑战,旨在确定每个用户按日期顺序售出的第二件商品是否属于其最喜爱的品牌。若用户销售的商品不足两件,则结果为否。查询在Oracle环境下实现,避免了LeetCode平台的限制。
题目难度

困难

题目描述

写一个 SQL 查询确定每一个用户按日期顺序卖出的第二件商品的品牌是否是他们最喜爱的品牌。如果一个用户卖出少于两件商品,查询的结果是 no 。
题目保证没有一个用户在一天中卖出超过一件商品。
在这里插入图片描述
在这里插入图片描述

正确答案

leetcode中mysql无法使用窗口函数,所以在oracle环境下编译代码

select t1.user_id as "seller_id",    
	case when t1.favorite_brand=i.item_brand then 'yes' else 'no' end as "2nd_item_fav_brand"
from     
	(
	SELECT u.user_id, u.favorite_brand, t.item_id    
	FROM Users u    
	LEFT JOIN 
		(
		SELECT item_id, seller_id        
		FROM (            
			SELECT order_date, item_id, seller_id, 
				row_number() OVER (PARTITION BY seller_id ORDER BY order_date) AS rank            
			FROM Orders           
			) a        
		WHERE a.rank = 2        
		) t    
	ON u.user_id = t.seller_id) t1
LEFT JOIN Items i
on t1.item_id=i.item_id
order by "seller_id"
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值