MySQL做题实战5||牛客的课程订单分析

简介:题目来自牛客网在线编程SQL实战,文章内容主要是讲解博主自己做题时的思路、相关见解以及要点总结。总的来说,就是明bug易改,暗bug难查,路漫漫其修远兮,吾将上下而求索!

一、题目内容一(难度:简单)

有一个订单信息表(order_info),简况如下:

第1行表示user_id为557336的用户在2025-10-10的时候使用了client_id为1的客户端下了C++课程的订单,但是状态为没有购买成功。

第2行表示user_id为230173543的用户在2025-10-12的时候使用了client_id为2的客户端下了Python课程的订单,状态为购买成功。

。。。

最后1行表示user_id为557336的用户在2025-10-24的时候使用了client_id为1的客户端下了Python课程的订单,状态为没有购买成功。

编写要求:

请写出一个sql语句查询在2025-10-15以后状态为购买成功的C++课程或者Java课程或者Python的订单,并且按照order_info的id升序排序,以上例子查询结果如下:

 解题思路:

 解题代码:

select *
from order_info
where date>'2025-10-15'
and status='completed'
and product_name in ('C++','Java','Python')
order by id;

比较总结:

  • 此题较为简单,主要考查筛选和排序。

二、题目内容二(难度:中等)

有一个订单信息表(order_info),简况如下:

第1行表示user_id为557336的用户在2025-10-10的时候使用了client_id为1的客户端下了C++课程的订单,但是状态为没有购买成功。

第2行表示user_id为230173543的用户在2025-10-12的时候使用了client_id为2的客户端下了Python课程的订单,状态为购买成功。

。。。

最后1行表示user_id为557336的用户在2025-10-25的时候使用了client_id为1的客户端下了C++课程的订单,状态为购买成功。

编写要求:

请写出一个sql语句查询在2025-10-15以后,同一个用户下单2个以及2个以上状态为购买成功的C++课程或Java课程或Python课程的user_id,并且按照user_id升序排序,以上例子查询结果如下(说明:id为4,6的订单满足以上条件,输出对应的user_id为57;id为5,7的订单满足以上条件,输出对应的user_id为557336;按照user_id升序排序。):

解题思路:

  解题代码:

select user_id
from order_info
where date>'2025-10-15'
and status='completed'
and product_name in ('C++','Python','Java')
group by user_id
having count(user_id)>=2
order by user_id;

比较总结:

  • 相比于第一题,题目要求多了个分组筛选,重难点在于区分是分组前筛选还是分组后筛选
  • 分组前筛选的关键词是where,不会搭配聚合函数(如count、min等)使用
  • 分组后筛选的关键词是having,一般搭配聚合函数使用

三、题目内容三(难度:中等)

有一个订单信息表(order_info),简况如下:

第1行表示user_id为557336的用户在2025-10-10的时候使用了client_id为1的客户端下了C++课程的订单,但是状态为没有购买成功。

第2行表示user_id为230173543的用户在2025-10-12的时候使用了client_id为2的客户端下了Pytho

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值