SQL模板-用户留存率计算

在这段实习中,我遇到了用户留存率计算的需求,这里做个总结。

首先来讲下,什么是用户留存?

在互联网行业中,用户在某段时间内开始使用应用,经过一段时间后,仍然继续使用该应用的用户。用户留存一般区分新增用户留存和活跃用户留存。通过区分不同属性的用户留存状况,对不同用户采取精细的运营策略。在用户基础上,还可通过时间维度进一步区分次日留存、周留存、月留存。

我们需要计算1到90天的用户留存率,经过上面的介绍,第N天用户留存率的计算公式就显而易见了:

我们设"第N天的用户留存率"为,"第N天登录的用户总数"为,"第一天创建账号的用户总数"为,则用户留存率的计算公式如下:

于是,我们可以得到如下的代码。其中,dt是登录/创号的日期,格式是yyyy-mm-dd。open_id是唯一的用户标识。表user_create_raw是记录用户创号信息的表,role_login_in是记录用户登陆信息的表,精确到一个账号的其中一个游戏角色。大致SQL如下:

sql 复制代码
SELECT a.dt, COUNT(DISTINCT a.open_id), COUNT(DISTINCT r.open_id), cast(COUNT(DISTINCT r.open_id) as double)/COUNT(DISTINCT a.open_id)*100 rate
FROM (
  SELECT open_id, MAX(dt) dt
  FROM user_create_raw u
  WHERE dt='2023-09-15' 
  GROUP BY open_id
)a
LEFT JOIN role_login_raw r ON a.open_id=r.open_id AND DATEDIFF(r.dt, a.dt)=1
GROUP BY a.dt

以上就是这么多,希望自己再接再厉。

相关推荐
GBASE15 分钟前
ITPUB专访南大通用——GBase 8s数据库以内核铸根基,以生态赢未来
数据库
GBASE25 分钟前
GBASE南大通用技术分享:构建最优数据平台,GBase 8s数据库安装准备(二)
数据库
林熙蕾LXL39 分钟前
SQL Server——基本操作
数据库·sql
GBASE1 小时前
GBASE南大通用技术分享:构建最优数据平台,GBase 8s数据库安装准备
数据库
IOT-Power1 小时前
树莓派 Ubuntu 24.04 开机换源总结
linux·数据库·ubuntu
阿华田5121 小时前
重试框架 -- Guava Retry
数据库
柠檬汁Dev1 小时前
还在等DBA给你库?我3分钟就拉起一个高可用集群
数据库·云计算·dba
安卓开发者2 小时前
鸿蒙NEXT应用数据持久化全面解析:从用户首选项到分布式数据库
数据库·分布式·harmonyos
少男的脸红藏不住心事2 小时前
GD32入门到实战35--485实现OTA
数据库·mongodb·nosql
爬山算法3 小时前
Redis(50) Redis哨兵如何与客户端进行交互?
数据库·redis·交互