每日一SQL 【游戏玩法分析 IV】

文章目录

问题

案例

执行顺序

SQL 语句的执行顺序(核心步骤)

同一层级的select查询内部, 别名在整个 SELECT 计算完成前不生效

使用分组解决

第一步

sql 复制代码
select  temp.*, a.event_date as second_date from
(select player_id, min(event_date) as first_date from Activity group by player_id) temp
left join Activity a on temp.player_id = a.player_id and date_add(temp.first_date, interval 1 day) = a.event_date;

解释

count(a.event_date):count关键字计算非空字段数量, count(*)计算全部数量.

1.先计算每个玩家的首次登陆日

2.再计算每个玩家的第二天登陆日, second_date不为null即表示该玩家符合条件

3.符合条件的玩家用count(second_date)控制, 全部玩家用count(*)控制, round(count(second_date) / count(*), 2) 计算完成.

第二步

sql 复制代码
select round(count(a.event_date) / count(*),2) as fraction from
(select player_id, min(event_date) as first_date from Activity group by player_id) temp
left join Activity a on temp.player_id = a.player_id and date_add(temp.first_date, interval 1 day) = a.event_date;
相关推荐
Joseit18 小时前
AI应用生成平台:数据库、缓存与存储
数据库·人工智能·缓存
迎風吹頭髮19 小时前
UNIX下C语言编程与实践9-UNIX 动态库创建实战:gcc 参数 -fpic、-shared 的作用与动态库生成步骤
c语言·数据库·unix
黑马金牌编程20 小时前
深入浅出 Redis:从核心原理到运维实战指南一
数据库·redis·缓存·性能优化·非关系型数据库
李迟20 小时前
2025年9月个人工作生活总结
服务器·数据库·生活
野犬寒鸦1 天前
从零起步学习Redis || 第四章:Cache Aside Pattern(旁路缓存模式)以及优化策略
java·数据库·redis·后端·spring·缓存
茉莉玫瑰花茶1 天前
Redis - Bitfield 类型
数据库·redis·缓存
lang201509281 天前
MySQL InnoDB备份恢复全指南
数据库·mysql
爱吃香蕉的阿豪1 天前
.NET Core 中 System.Text.Json 与 Newtonsoft.Json 深度对比:用法、性能与场景选型
数据库·json·.netcore
mpHH1 天前
postgresql中的默认列
数据库·postgresql
jllws11 天前
数据库原理及应用_数据库基础_第4章关系模型的基本理论_数据库完整性规则和MySQL提供的约束
数据库