题解 | #每天的日活数及新用户占比#

每天的日活数及新用户占比

https://www.nowcoder.com/practice/dbbc9b03794a48f6b34f1131b1a903eb

select dt
        ,count(distinct au.uid) AS dau
        ,round(count(distinct nu.uid)/count(distinct au.uid),2) AS uv_new_ratio
from(
    select uid
        ,date(in_time) AS dt
    from tb_user_log
    union 
    select uid
            ,date(out_time) AS dt
    from tb_user_log
)au
left join
(
    select uid
            ,date(min(in_time)) AS fd
    from tb_user_log
    group by uid
)nu on au.dt = nu.fd and au.uid =  nu.uid
group by dt
order by dt asc

1、日活用户 left join 新户

2、union可以去重,所以uid,in_time union uid,out_time可以把in_time和out_time跨天的uid作为两天的活跃用户给筛选出来。

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-09 12:20
点赞 评论 收藏
分享
下个早班:秒挂就是不缺人
点赞 评论 收藏
分享
06-12 16:00
天津大学 Java
牛客30236098...:腾讯坏事做尽,终面挂是最破防的 上次被挂了后我连简历都不刷了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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