首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用SQL计算留任/流失

使用SQL计算留任/流失
EN

Stack Overflow用户
提问于 2020-07-03 06:45:13
回答 1查看 190关注 0票数 0

我已经创建了一个派生表,它应该非常接近于计算流失,但似乎无法获得最终答案

代码语言:javascript
运行
复制
account_id     current_month_paid     last_month_paid    next_month_paid
 633               2018-10                NULL                NULL
 862               2018-10                NULL              2018-11
 862               2018-11               2018-10            2018-12
 862               2018-12               2018-11            2019-01
1448               2018-10                NULL              2018-11

如何对这些列进行分组,以便每月获得保留率,如下所示:

代码语言:javascript
运行
复制
2018-10       2018-11       2018-12
  92%          94%            93%

任何帮助都将不胜感激。我在使用AWS雅典娜,以防万一

编辑:这些是样本百分比,它们不是实际计算。我希望按月分组,并显示前一个月支付的百分比(每个帐户ID)

EN

回答 1

Stack Overflow用户

发布于 2020-07-05 03:15:16

派生表的语义对我来说不是很清楚,但假设

  • last_month_paid = null对于给定月份的新用户,and
  • next_month_paid = null表示用户在给定月份有最后一次付款。我会使用以下内容:

代码语言:javascript
运行
复制
WITH paying_user_stats AS (
    SELECT
        account_id,
        current_month_paid,
        1 as paying_users,
        case when last_month_paid is null then 1 else 0 end as paying_users_new,
        case when next_month_paid is null then 1 else 0 end as paying_users_churn
    FROM accounts
)
SELECT
    current_month_paid,
    sum(paying_users) as paying_users,
    sum(paying_users-paying_users_new) as paying_users_month_begin,
    sum(paying_users-paying_users_churn) as paying_users_month_end,
    sum(paying_users_new) as paying_users_new,
    sum(paying_users_churn) as paying_users_churn
FROM paying_user_stats
GROUP BY current_month_paid

现在,如果我没有理解错您对保留率的定义,您正在寻找的是sum(paying_users)/sum(paying_users_month_begin)。您可能希望在BI工具、电子表格等查询之外执行该划分,以避免意外地将其聚合为未加权平均值等问题。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62706059

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档