当前位置: 首页 > wzjs >正文

做购物网站 营业范围是什么建站系统哪个好

做购物网站 营业范围是什么,建站系统哪个好,做视频网站可行吗,广州建论坛网站一、问题拆解:理解次日留存率的计算逻辑 1.1 业务需求转换 题目:运营希望查看用户在某天刷题后第二天还会再来刷题的留存率。 关键分析点: 留存率 (第一天刷题且第二天再次刷题的用户数) / 第一天刷题的总用户数需…

一、问题拆解:理解次日留存率的计算逻辑

1.1 业务需求转换

题目:运营希望查看用户在某天刷题后第二天还会再来刷题的留存率。

关键分析点

  • 留存率 = (第一天刷题且第二天再次刷题的用户数) / 第一天刷题的总用户数
  • 需要关联同一用户的连续两天行为
  • 结果要求不去重(保留所有可能的留存行为)

1.2 数据模型假设

假设我们有用户刷题记录表question_practice_detail,包含:

  • device_id:用户设备ID(唯一标识用户)
  • date:刷题日期
  • 其他字段:题目ID、答题结果等(与本次计算无关)

二、核心SQL解析:自连接实现留存关联

2.1 完整SQL语句

SELECT COUNT(DISTINCT q2.device_id, q2.date) / COUNT(DISTINCT q1.device_id, q1.date) AS avg_ret
FROM question_practice_detail AS q1 
LEFT JOIN question_practice_detail AS q2 
ON q1.device_id = q2.device_id AND DATEDIFF(q2.date, q1.date) = 1;

2.2 自连接设计原理

表别名技术

  • q1:作为主表,表示"第一天刷题记录"
  • q2:作为关联表,表示"第二天刷题记录"

连接条件解析

  1. q1.device_id = q2.device_id:确保关联同一用户的记录
  2. DATEDIFF(q2.date, q1.date) = 1:确保q2的日期比q1晚一天

左连接的意义

  • 即使某用户在次日没有刷题记录(q2为NULL),q1的记录仍会被保留
  • 这保证了分母(所有第一天刷题用户)的完整性

三、COUNT(DISTINCT …) 多字段去重详解

3.1 多字段去重的内在逻辑

COUNT(DISTINCT q2.device_id, q2.date)

执行步骤

  1. 组合键生成:将device_iddate组合成复合键(如1001-2023-01-02
  2. 哈希去重:数据库内部使用哈希表对组合键进行去重
  3. 计数统计:统计去重后的组合键数量

与单字段去重的区别

表达式统计逻辑
COUNT(DISTINCT device_id)统计不同用户的数量
COUNT(DISTINCT date)统计不同日期的数量
COUNT(DISTINCT device_id, date)统计不同用户+日期的组合数量

3.2 分子与分母的统计逻辑

分子COUNT(DISTINCT q2.device_id, q2.date)

  • 统计有次日刷题记录的(用户ID, 日期)组合数
  • 确保每个用户每天只被统计一次

分母COUNT(DISTINCT q1.device_id, q1.date)

  • 统计所有第一天刷题的(用户ID, 日期)组合数
  • 覆盖所有可能产生留存的基础用户

四、执行流程与数据流转

4.1 示例数据与连接过程

假设我们有以下数据:

q1表(第一天刷题记录)

device_iddate
10012023-01-01
10022023-01-01
10032023-01-01

q2表(第二天刷题记录)

device_iddate
10012023-01-02
10012023-01-02

自连接结果

q1.device_idq1.dateq2.device_idq2.date
10012023-01-0110012023-01-02
10022023-01-01NULLNULL
10032023-01-01NULLNULL

4.2 统计过程详解

  1. 分子计算

    • COUNT(DISTINCT q2.device_id, q2.date) = 1
    • 去重后只有(1001, 2023-01-02)这一个有效组合
  2. 分母计算

    • COUNT(DISTINCT q1.device_id, q1.date) = 3
    • 包含(1001, 2023-01-01)(1002, 2023-01-01)(1003, 2023-01-01)
  3. 结果

    • 次日留存率 = 1/3 ≈ 33.33%

五、性能优化策略

5.1 复合索引设计

-- 创建覆盖索引,同时加速连接和去重
CREATE INDEX idx_device_date ON question_practice_detail(device_id, date);

索引优化原理

  • 支持device_id的等值查询
  • 支持date的范围查询(DATEDIFF本质是日期比较)
  • 覆盖索引避免回表,直接在索引中完成统计

5.2 执行计划分析

使用EXPLAIN关键字分析SQL执行计划:

EXPLAIN
SELECT ... (SQL) ...;

关键指标解读

  • type列:理想情况为refrange,避免ALL(全表扫描)
  • key列:应显示使用了idx_device_date索引
  • Extra列:避免出现Using temporaryUsing filesort

六、常见问题与解决方案

6.1 NULL值处理

-- 假设存在device_id=NULL的记录
COUNT(DISTINCT device_id, date)  -- 会忽略这些记录-- 如需包含NULL,需手动转换
COUNT(DISTINCT COALESCE(device_id, 0), date)

6.2 分母为零处理

当某天没有用户刷题时,直接计算会导致除零错误:

SELECT IFNULL(COUNT(DISTINCT q2.device_id, q2.date) / NULLIF(COUNT(DISTINCT q1.device_id, q1.date), 0), 0) AS avg_ret
FROM ...

6.3 时间窗口扩展

计算3日留存率:

SELECT COUNT(DISTINCT q3.device_id) / COUNT(DISTINCT q1.device_id) AS retention_3day
FROM question_practice_detail AS q1 
LEFT JOIN question_practice_detail AS q3 
ON q1.device_id = q3.device_id AND DATEDIFF(q3.date, q1.date) = 3;

七、总结与技术要点

7.1 核心技术点回顾

  1. 自连接技术:通过表别名实现同一表的不同时间关联
  2. COUNT(DISTINCT):多字段组合去重统计的关键
  3. LEFT JOIN:确保分母统计的完整性,包含所有可能留存的用户
  4. 索引优化:复合索引显著提升大数据量下的查询性能

7.2 技术决策树

开始
│
├── 是否需要统计用户行为留存率?
│   │
│   └── 是 → 是否需要多日留存?
│       │
│       ├── 是 → 使用DATEDIFF调整时间窗口
│       │
│       └── 否 → 是否需要去重?
│           │
│           ├── 是 → 使用COUNT(DISTINCT ...)
│           │
│           └── 否 → 直接使用COUNT
│
├── 是否存在性能问题?
│   │
│   └── 是 → 创建复合索引(用户ID, 日期)
│
└── 结束

通过深入理解自连接和多字段去重的原理,结合索引优化技术,我们可以高效、准确地计算各种时间窗口的用户留存率。

http://www.dtcms.com/wzjs/190326.html

相关文章:

  • 广东今科网站建设浙江网站建设推广
  • 文案策划网站网站如何被搜索引擎收录
  • 厦门企业建站模板电商营销推广方案
  • 网络营销网站建设设计方案最新的疫情信息
  • 网站建设范文网络推广费用
  • 个人建站流程详解海外网络推广平台
  • 网站域没到期不能续费吗百度秒收录排名软件
  • phpweb企业网站管理系统今日头条国际军事新闻
  • 展厅设计公司西安网站seo快速优化
  • 网站流量30g谷歌浏览器免费入口
  • 做国际贸易网站要什么条件全球网站流量查询
  • 深圳开发网站的公司哪家好seo好学吗入门怎么学
  • web服务器软件有哪些汕头最好的seo外包
  • 企业网站建设第一步黑龙江暴雪预警
  • 做网站充值犯法吗西安网站seo
  • 日照哪里做网站长沙互联网推广公司
  • 怎么注册17做网站福建seo快速排名优化
  • 免费做网站黑帽友情链接
  • 网站建设项目可行性报告如何优化网站快速排名
  • 360免费建站不要钱seo服务加盟
  • 旅游网站建设色彩搭配表重庆网站制作公司
  • 网站如何备案 流程图莫停之科技windows优化大师
  • 郑州制作网站网店代运营骗局
  • 信阳网站建设信阳什么网站都能进的浏览器
  • 建设网站比较好semester
  • wordpress换域名后seo发外链工具
  • 网站怎么做才能被百度抓取到上海优化网站方法
  • 湘潭哪里做网站 电话seo关键字优化软件
  • 成都的网站设计公司价格数字经济发展情况报告
  • 网站做nat映射需要哪些端口百度云盘登录