栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

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

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

原题链接

需求

查询在2025-10-15以后,同一个用户下单2个以及2个以上状态为购买成功的C++课程或Java课程或Python课程的来源信息,第一列是显示的是客户端名字,如果是拼团订单则显示GroupBuy,第二列显示这个客户端(或者是拼团订单)有多少订单,最后结果按照第一列(source)升序排序,如下

步骤一:根据条件需要找出来源信息,找出满足条件的user_id
select
    user_id
from order_info
where status = 'completed'
and product_name in ('C++', 'Java', 'Python')
and date > '2025-10-15'
group by user_id
having count(*) > 1
步骤二:将选择的user_id作为条件,从原表中筛选出属于来源信息部分,并根据client_id分组计数
select
    client_id,
    count(*) as cnt
from order_info
where user_id in (
    select
        user_id
    from order_info
    where status = 'completed'
    and product_name in ('C++', 'Java', 'Python')
    and date > '2025-10-15'
    group by user_id
    having count(*) > 1
)
and status = 'completed'
and product_name in ('C++', 'Java', 'Python')
and date > '2025-10-15'
group by client_id
步骤三:将步骤二的结果与client表left join,并采用ifnull函数将null值设置为“GrouBuy”,即最终结果
select
    finull(c.name, 'GroupBuy') as source,
    t.cnt
from (
    select
        client_id,
        count(*) as cnt
    from order_info
    where user_id in (
        select
            user_id
        from order_info
        where status = 'completed'
        and product_name in ('C++', 'Java', 'Python')
        and date > '2025-10-15'
        group by user_id
        having count(*) > 1
                      )
    and status = 'completed'
    and product_name in ('C++', 'Java', 'Python')
    and date > '2025-10-15'
    group by client_id
      ) as t
left join client as c
on t.client_id = c.id
order by source
思路来自题解区第二个答案

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/643940.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号