SQL 81) 牛客的课程订单分析(五)

牛客的课程订单分析(六)

http://www.nowcoder.com/questionTerminal/c5736983c322483e9f269dd23bdf2f6f

解法和前几题类似
需要注意的点

表连接时需要使用left join来左连结order_info表,因为client_id = 0这个数据在client表里是不存在的,会在连结时被去掉

select o.id, o.is_group_buy ,
case when o.is_group_buy = 'No'then c.name else NULL end
from order_info as o left join client as c
on o.client_id = c.id
where user_id in
(select user_id
from order_info
where date >'2025-10-15'
and product_name in ('C++','Java','Python')
and status = 'completed'
group by user_id
having count(id) > 1)
and o.date > '2025-10-15'
and o.product_name in ('C++','Java','Python')
and o.status = 'completed'
order by o.id asc
SQL 文章被收录于专栏

SQL

全部评论
您好,请问为什么要限制where user_id in那么一堆啊?
点赞 回复 分享
发布于 2021-07-26 10:14
为了筛选购买两次以上的用户
点赞 回复 分享
发布于 2021-11-13 01:39
直接取name,不用case when吧,左连接连接不到就是null了
点赞 回复 分享
发布于 05-11 17:17 广东

相关推荐

已老实求offer😫:有点像徐坤(没有冒犯的意思哈)
点赞 评论 收藏
分享
ArisRobert:统一解释一下,第4点的意思是,公司按需通知员工,没被通知到的员工是没法去上班的,所以只要没被通知到,就自动离职。就是一种比较抽象的裁员。
点赞 评论 收藏
分享
25 收藏 评论
分享
牛客网
牛客企业服务