题解 | #每月及截止当月的答题情况#

每月及截止当月的答题情况

https://www.nowcoder.com/practice/1ce93d5cec5c4243930fc5e8efaaca1e

# 计算每月的月活用户数,其他都以此推算而来
# 难点在于新增用户,需要模仿矩阵
WITH temp_0 AS(
SELECT uid, exam_id, DATE_FORMAT(start_time, "%Y%m") start_month, 
	# 定义新增用户,将单个用户首次登录的时间定义为最初时间,只有等于该时间的才算是首次登录1,其他都是老用户登录
    IF(start_time = MIN(start_time) OVER(PARTITION BY uid), 1, 0) first_time
FROM exam_record
)
# 查询,直接统计月活用户数,对每月的首次登录的用户数求和得到新增用户数,然后根据新增用户数类推出后两个字段
SELECT start_month, COUNT(DISTINCT uid) mau,
        SUM(first_time) month_add_uv,
        MAX(SUM(first_time)) OVER(ORDER BY start_month) max_month_add_uv,
        SUM(SUM(first_time)) OVER(ORDER BY start_month) cum_sum_uv
FROM temp_0
GROUP BY start_month

全部评论

相关推荐

2025-12-25 16:26
已编辑
河北科技学院 Java
勇敢的牛油不服输:2800-300那不等于2500一个月吗兄弟们
点赞 评论 收藏
分享
2025-12-11 14:24
门头沟学院 Java
牛客35720396...:不要用boss,全是骗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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