题解 | #计算用户的平均次日留存率#

计算用户的平均次日留存率

https://www.nowcoder.com/practice/126083961ae0415fbde061d7ebbde453

distinct可用于选择不同的元组

select count(qp2.device_id)/count(qp1.device_id)
# count(*)
# sum(
#     case when qp2.id is null then 0
#          else 1
#     end
# ) as 'avg_ret'#/count(*)
from 
    (select DISTINCT device_id, date from question_practice_detail) as qp1
 left join 
    (select DISTINCT device_id, date from question_practice_detail) as qp2
on qp1.device_id=qp2.device_id and qp2.date=qp1.date+1
# 

# select *
# from question_practice_detail qp1 left join question_practice_detail qp2 on qp2.date=qp1.date+1
# where qp2.id is null

全部评论

相关推荐

点赞 评论 收藏
分享
01-17 12:35
吉首大学 Java
秋招之BrianGriffin:自己的工作自己做!😡
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务