题解 | #平均活跃天数和月活人数#

平均活跃天数和月活人数

http://www.nowcoder.com/practice/9e2fb674b58b4f60ac765b7a37dde1b9

要求

请计算2021年每个月里试卷作答区用户平均月活跃天数avg_active_days和月度活跃人数mau

思路

  1. 2021年: YEAR(submit_time) = 2021
  2. 每个月: group by month -- extract(YEAR_MONTH from submit_time) as month -- YEAR_MONTH 能直接取出年月
  3. 用户平均月活跃天数: round(count(distinct concat(uid,date(submit_time))) / count(distinct uid),2)

相同用户同一天多次答题只算一天所以这里要用distinct去除同一uid一天内多次答题。 并且,两个不同用户同一天答题算两天,所以为了识别是同一用户一天内多次答题还是不同用户同一天答题,我们用 concat(uid,date(submit_time) 将 uid 和 日期剪贴到一起,这样就能用count 正确的计算了。下面是concat(uid,date(submit_time) 的输出结果 (如果想好看点,中间可以加个空格分隔开)

alt

PS:这里只要date,不要把time一起加上去,因为同一天不同时间提交会导致重复计算。

  1. mau: count(distinct uid)

实现

select extract(YEAR_MONTH from submit_time) as month,
round(count(distinct concat(uid,date(submit_time))) / count(distinct uid),2)  as avg_active_days,
count(distinct uid) as mau
from exam_record
where year(submit_time) = 2021 and submit_time is not null
group by month
全部评论
hhh我也用了concat,但看评论区发现不用concat也行
点赞 回复 分享
发布于 2022-09-14 10:19 上海

相关推荐

榕城小榕树:1200单休,我去干点啥别的不好
点赞 评论 收藏
分享
本2硕9,秋招不想努力海投了
小何和:行情再不好也不可能拒绝你,不可能只要双9的
点赞 评论 收藏
分享
06-02 15:53
阳光学院 Java
点赞 评论 收藏
分享
Twilight_m...:表格简历有点难绷。说说个人看法: 1.个人基本情况里好多无意义信息,什么婚姻状况、健康状况、兴趣爱好、户口所在地、身份证号码、邮政编码,不知道的以为你填什么申请表呢。 2.校内实践个人认为对找工作几乎没帮助,建议换成和测开有关的项目,实在没得写留着也行。 3.工作经历完全看不出来是干什么的,起码看着和计算机没啥关系,建议加强描述,写点你在工作期间的实际产出、解决了什么问题。 4.个人简述大而空,看着像AI生成,感觉问题最大。“Python,C,C++成为我打造高效稳定服务的得力工具”、“我渴望凭借自身技术知识与创新能力,推动人工智能技术的应用发展,助力社会实现智能化转型”有种小学作文的美感。而且你确定你个人简述里写的你都会嘛?你AI这块写的什么“深入研究”,发几篇顶会的硕博生都不一定敢这么写。而且你AI这块的能力和软测也完全无关啊。个人简述建议写你对哪些技术栈、哪些语言、哪些生产工具的掌握,写的有条理些,而且最好是和测开强相关的。
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-04 18:06
点赞 评论 收藏
分享
评论
3
收藏
分享

创作者周榜

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