题目描述:
SQL架构
Table: Activity
(player_id,event_date)是此表的主键。
这张表显示了某些游戏的玩家的活动情况。
每一行是一个玩家的记录,他在某一天使用某个设备注销之前登录并玩了很多游戏(可能是 0)。
编写一个 SQL 查询,报告在首次登录的第二天再次登录的玩家的分数,四舍五入到小数点后两位。换句话说,您需要计算从首次登录日期开始至少连续两天登录的玩家的数量,然后除以玩家总数。
查询结果格式如下所示:
方法1:
主要思路:
# Write your MySQL query statement below
select round(count(distinct a.player_id)/(select count(distinct player_id) from activity),2) as fraction
from activity a join (select player_id,min(event_date) as first_log from activity group by player_id) as b
on a.player_id=b.player_id and datediff(a.event_date,b.first_log)=1;