MySQL做题实战2||实习广场投递简历分析

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

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

在牛客实习广场有很多公司开放职位给同学们投递,同学投递完就会把简历信息存到数据库里。

现在有简历信息表(resume_info),部分信息简况如下:

第1行表示,在2025年1月2号,C++岗位收到了53封简历

。。。

最后1行表示,在2026年1月4号,Java岗位收到了230封简历

编写要求:

请写出SQL语句查询在2025年内投递简历的岗位和数量,并且按数量降序排序,以上例子查询结果如下:

 解题思路:

解题代码:

select job,sum(num) as cnt
from resume_info
where date<'2026-1-1'
group by job
order by cnt desc;

比较总结:

  • 这道题十分简单,主要考查筛选、分组和排序

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

在牛客实习广场有很多公司开放职位给同学们投递,同学投递完就会把简历信息存到数据库里。

现在有简历信息表(resume_info),部分信息简况如下:

第1行表示,在2025年1月2号,C++岗位收到了53封简历

。。。

最后1行表示,在2026年2月6号,C++岗位收到了231封简历

编写要求:

请写出SQL语句查询在2025年内投递简历的每个岗位,每一个月内收到简历的数量,并且按先按月份降序排序,再按简历数目降序排序,以上例子查询结果如下:

解题思路:

 解题代码:

select distinct job,date_format(date,'%Y-%m') as mon,
sum(num)over(partition by job, month(date)) as cnt
from resume_info
where date<'2026-1-1'
order by mon desc,cnt desc;

比较总结:

  • 这道题主要考查函数的使用,学会灵活使用date_format()函数和sum()over(partition by )的用法会简单很多
  • 此题的另一解法:其中,使用substr(date,1,7) 截取日期前七位,得到 年+月;substr(date,1,4) --截取日期前四位,得到 年
    select job,substr(date,1,7) as mon,sum(num) as cnt from resume_info
    where substr(date,1,4)='2025'
    group by job,mon
    order by mon desc,cnt desc

三、题目内容三(难度:困难)

在牛客实习广场有很多公司开放职位给同学们投递,同学投递完就会把简历信息存到数据库里。

现在有简历信息表(resume_info),部分信息简况如下:

第1行表示,在2025年1月2号,C++岗位收到了53封简历

。。。

最后1行表示,在2027年2月6号,C++岗位收到了231封简历

编写要求:

请写出SQL语句查询在2025年投递简历的每个岗位,每一个月内收到简历的数目,和对应的2026年的同一个月同岗位,收到简历的数目,最后的结果先按first_year_mon月份降序,再按job降序排序显示,以上例子查询结果如下:

解析:第1行表示Python岗位在2025年2月收到了93份简历,在对应的2026年2月收到了846份简历;最后1行表示C++岗位在2025年1月收到了107份简历,在对应的2026年1月收到了470份简历

解题思路:

解题代码:

select table1.job,first_year_mon,first_year_cnt,second_year_mon,second_year_cnt
from (
    select distinct job,date_format(date,'%Y-%m') as 'first_year_mon',
    sum(num)over(partition by job,month(date)) as 'first_year_cnt',month(date) as md
    from resume_info
    where date>'2024-12-31' and date<'2026-1-1'
) as table1
left join (
    select distinct job,date_format(date,'%Y-%m') as 'second_year_mon',
    sum(num)over(partition by job,month(date)) as 'second_year_cnt',month(date) as md
    from resume_info
    where date>'2025-12-31' and date<'2027-1-1'
) as table2 on table1.job=table2.job
where table1.md=table2.md
order by first_year_mon desc,table1.job desc;

比较总结:

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值