文章目录
问题

案例

执行顺序

同一层级的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;