面试SQL题 计算每年在校生人数

**题目均来自社区同学遇到面试题**

有一个录取学生人数表,记录的是每年录取学生人数和入学学生的学制,然后计算每年在校生人数

with data as (
--             主键        入学年份            人数            学制
    select 1 as id , 2001 as year , 1200 as stu_num , '3' as stu_len union all
    select 2 as id , 2000 as year , 1300 as stu_num , '5' as stu_len union all
    select 3 as id , 2003 as year , 1400 as stu_num , '4' as stu_len union all
    select 4 as id , 2002 as year , 1500 as stu_num , '3' as stu_len union all
    select 5 as id , 2002 as year , 1600 as stu_num , '2' as stu_len
)
select
  year,
  sum(stu_num) -- 聚合在校生
from
  (
    select
      id,
      (year + pos) as year, 
      stu_num,
      stu_len,
      val
    from
      data 
    lateral view 
        posexplode(
            split(space( cast(stu_len as int) ) , '(?!$)' ) --产生学制数个空格并切割
            --split(space( cast(stu_len as int) - 1 ) , ' ' ) --不用正则的写法,效果同上
        ) -- posexplode 炸裂函数 返回带下标的表
        t as pos,val -- posexplode 炸裂函数 返回 下标和具体值
  ) t -- 派生表别名
group by
  year -- 按照年份分组,聚合在校生

答案如下

炸裂函数是面试常考的知识点,也是区分候选人SQL思维高低的好办法,建议熟练掌握

更多实战题目和解法思路尽在社区,还有视频讲解哦

#数据人的面试交流地##SQL面试#
全部评论

相关推荐

美团面了大概四十分钟,全程细节拷打,面完汗流浃背,感觉过不了了,看面经吧1. 说说你平时是怎么送餐的?直接傻瓜式回答拧车把就走了2. 如果送餐途中下雨了,你会怎么办?回答找个地方躲着,然后就问我那订单超时怎么办,答不出来了。。。3. 如果有个地方爆单,同时有多个不同楼层但是是同一栋楼的地方下单,可能是什么情况?答不出来,乱蒙了个可能在开派对,有没有大佬知道的4. 如果到了商家,但商家还没把餐备好,你会怎么做?直接回答干等着了,然后感觉这样回答不太好,又补了句我可能会催催商家。。。5. 实际送餐过程中有没有考虑过使用多部手机?我说配送账号就一个,没必要使用多部手机。面试官好像不太满意6. 送到餐了,但客户一直不来取餐,你会怎么办?阻塞等待吗?我说会打电话催促客户,客户一直不来的话就把餐放到地点,然后拍照走人,然后问我这样做有没有考虑过外卖丢失的情况,外卖丢失怎么办,完了,又掉进坑了7. 有没有送错餐的情况?我说实际没遇过这种场景,面试官又不太满意了。。。搞不懂,一定要有实际解决过出错的经验吗。。。没出错不是更好吗。。。8. 餐箱满了,但你又接单了,餐箱放不下了,出现了Out Of Box,如何解决?我说一般我会每次接单前检查下餐箱容量,有空间才会接新的单,又追问这样会不会影响接单效率,如果被其它骑手抢单了怎么办?完了,又又掉进坑了。。。9. 送餐过程有没有把外卖进行分类?我说我一般电动车前后有两个餐箱,前面放带有汤水易撒的,后面放比较干的外卖。总算是能答出一题了10. 看了下我送的最快的一单,问我为什么那一单10s就送达了。因为客户就在店里面,当堂点外卖是为了用券。。。我这个订单是不是有点水了,但鼠鼠是真没什么订单拿得出手了做了道算法,一道贪心,给定单子信息,寻找最短配送路线,之前刷过,10分钟a出来了。
美团一面879人在聊 查看10道真题和解析
点赞 评论 收藏
转发
2 6 评论
分享
牛客网
牛客企业服务