Mysql求留存率(困难)——游戏玩法分析Ⅲ

以游戏玩法分析为例求玩家的留存率

问题描述

Column NameType
player_idint
device_idint
event_datedate
games_playedint

 (player_id,event_date)是此表的主键,这张表显示了某些游戏的玩家的活动情况。每一行是一个玩家的记录,他在某一天使用某个设备注销之前登录并玩了很多游戏(可能是 0)

 我们将玩家的安装日期定义为该玩家的第一个登录日。

 我们还将某个日期 X 的第 1 天留存时间定义为安装日期为 X 的玩家的数量,他们在 X 之后的一天重新登录,除以安装日期为 X 的玩家的数量,四舍五入到小数点后两位。

 编写一个 SQL 查询,报告每个安装日期、当天安装游戏的玩家数量和第一天的留存时间。

示例

Activity 表:

player_iddevice_idevent_dategames_played
122016-03-015
122016-03-026
232017-06-251
312016-03-010
342016-07-035

Result 表:

install_dtinstallsDay1_retention
2016-03-0120.50
2017-06-2510.00

 玩家 1 和 3 在 2016-03-01 安装了游戏,但只有玩家 1 在 2016-03-02 重新登录,所以 2016-03-01 的第一天留存时间是 1/2=0.50
 玩家 2 在 2017-06-25 安装了游戏,但在 2017-06-26 没有重新登录,因此 2017-06-25 的第一天留存时间为 0/1=0.00

解答

select install_dt, count(distinct player_id) as installs, 
round(sum(if(datediff(event_date, install_dt)=1, 1, 0)) / count(distinct player_id), 2) as Day1_retention
from (
    select *,  
    min(event_date) over(partition by player_id order by event_date asc) as install_dt
    from Activity
) as t
group by install_dt

分析

 用窗口函数,但要注意group by 的用法,另外在select中,不能将前一个查询的字段用于后续中,比如用count(distinct player_id),而不能用installs。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值