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

平均活跃天数和月活人数

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

WITH v1 AS(
    SELECT uid, REPLACE(LEFT(submit_time, 10), '-', '') month
    FROM exam_record
    WHERE submit_time IS NOT NULL AND YEAR(submit_time) = 2021
)

SELECT LEFT(month,6) the_date,
    ROUND(COUNT(DISTINCT uid, month)/COUNT(DISTINCT uid), 2) avg_active_days,
    COUNT(DISTINCT uid) mau
FROM v1
GROUP BY the_date
ORDER BY the_date

题解:

任务是求21年每月的平均活跃天数和月活人数

思路:

每月,那就是分组groupby

月活人数就是查找每月的uid的个数,去重

难点在平均活跃天数,最先我理解的是每月的记录出现的次数就是活跃的总天数,最先写的代码就是

ROUND(COUNT(*)/COUNT(DISTINCT uid), 2) avg_active_days,

但是根据题干,101活跃1天,这样理解,就是要找到每个用户活跃了几天,如果101用户在某一天有多次提交记录呢?那算一天还是多天?答案是一天

所以要使用distinct

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-11 12:31
以前小时候我最痛恨出轨、偷情的人,无论男女,为什么会出轨?现在我成了自己最讨厌的人,没想到分享的东西在牛客会被这么多人看,大家的评价都很中肯,我也认同,想过一一回复,但我还是收声了,我想我应该说说这件事,这件事一直压在我心里,是个很大的心结,上面说了人为什么出轨,我大概能明白了。我们大一下半年开始恋爱,开始恋爱,我给出了我铭记3年的承诺,我对她好一辈子,我永远不会背叛,我责任心太重,我觉得跟了我,我就要照顾她一辈子,我们在一起3年我都没有碰过她,她说往东我就往东,她说什么我做什么,她要我干什么,我就干什么!在学校很美好,中途也出过一些小插曲,比如男闺蜜、男闺蜜2号等等等。但我都强迫她改掉了,我...
牛客刘北:两个缺爱的人是没有办法好好在一起的,但世界上哪有什么是非对错?你后悔你们在一起了,但是刚刚在一起的美好也是真的呀,因为其他人的出现,你开始想要了最开始的自己,你的确对不起自己,21岁的你望高物远,你完全可以不谈恋爱,去过你想要的生活,你向往自由,在一起之后,你要想的不是一个人,而是两个人,你不是变心了,就像你说的,你受够了,你不想包容了,冷静几天是你最优的选择,爱人先爱己。
社会教会你的第一课
点赞 评论 收藏
分享
06-28 22:48
已编辑
广东金融学院 Java
小浪_Coding:学院本+这俩项目不是buff叠满了嘛
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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