题解 | #月总刷题数和日均刷题数#

月总刷题数和日均刷题数

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

一、明确需求:

  1. 时间:2021年每月
  2. month_q_cnt = 该月刷题记录总数
  3. month_q_cnt = 用户总刷题数/该月总天数
  4. 2021汇总列

二、逻辑思路

  1. 用year(submit_time) =2021筛选数据
  2. 用date_format()提取‘年-月’字段作为后续分组条件,day(last_day())提取该月天数,作为后续mon_q_cnt计算
  3. 以年-月为分组条件,计算刷题总数和日均刷题数
  4. 以年为分组条件,计算汇总行,union合并3得到的结果
  5. 以submit_month为排列条件
with 
#选择2021,提取年,年-月,该月总天数
t1 as 
(select distinct *
        , year(submit_time) y
        , day(last_day(submit_time)) d 
        , date_format(submit_time,'%Y%m') y_m 
    from practice_record
    where year(submit_time) =2021
),

# 以年-月为分组条件,计算月答题数和日均答题数
t2 as
(select y_m
    , count(1) m_cnt
    , round(count(1)/avg(d),3) avg_d
from t1 
group by y_m)

#union联结汇总行
select y_m submit_month
    , m_cnt month_q_cnt
    , avg_d avg_day_q_cnt 
from t2 
union 
select '2021汇总',sum(m_cnt),round(sum(m_cnt)/31,3) avg_d_q 
from t2 
order by submit_month

拓展: 计算每个月的总天数:day(last_day(日期))

全部评论

相关推荐

在改简历的大卫很认真:天天有面试 = 你已经在 offer 门口了。 海投能面成这样,说明你的简历、基础、学历都是过关的,缺的只是一次刚好匹配的缘分。 关于你说的 SQL 恐惧,我帮你捋一下: - 面试里考来考去,真就那几类: 分组、去重、关联、子查询、窗口函数(row_number、rank、sum 开窗) ​ - 面试官要的不是“写得花里胡哨”,而是思路稳、不出错。 你恐惧的本质不是不会, 是怕临场卡壳、怕写错、怕被追问。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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