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 广东

相关推荐

头像
11-21 11:39
四川大学 Java
是红鸢啊:忘了还没结束,还有字节的5k 违约金
点赞 评论 收藏
分享
25 收藏 评论
分享
牛客网
牛客企业服务