题解 | #牛客的课程订单分析(六)#

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

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

SELECT d.id,d.is_group_buy,
CASE
WHEN d.is_group_buy='Yes' THEN NULL
ELSE client.name
END
FROM (
SELECT c.*
FROM (
SELECT b.user_id
FROM order_info AS b
WHERE b.date>'2025-10-15' AND b.status='completed' AND b.product_name IN ('C++','Java','Python')
GROUP BY b.user_id
HAVING COUNT(*)>=2
) AS a,order_info AS c
WHERE a.user_id=c.user_id AND c.date>'2025-10-15' AND c.status='completed' AND c.product_name IN ('C++','Java','Python')
) AS d LEFT JOIN client
ON d.client_id=client.id
ORDER BY d.id

先找到符合条件的订单,然后再连接,使用CASE WHEN结构

全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务