MySQL基础练习题34-游戏玩法分析4

目录

题目

准备数据

分析数据

总结


题目

报告在首次登录的第二天再次登录的玩家的 比率四舍五入到小数点后两位。换句话说,你需要计算从首次登录日期开始至少连续两天登录的玩家的数量,然后除以玩家总数。

准备数据

sql 复制代码
## 创建库
create database db;
use db;

## 创建表
Create table If Not Exists Activity (player_id int, device_id int, event_date date, games_played int)

## 向表中插入数据
Truncate table Activity
insert into Activity (player_id, device_id, event_date, games_played) values ('1', '2', '2016-03-01', '5')
insert into Activity (player_id, device_id, event_date, games_played) values ('1', '2', '2016-03-02', '6')
insert into Activity (player_id, device_id, event_date, games_played) values ('2', '3', '2017-06-25', '1')
insert into Activity (player_id, device_id, event_date, games_played) values ('3', '1', '2016-03-02', '0')
insert into Activity (player_id, device_id, event_date, games_played) values ('3', '4', '2018-07-03', '5')

activity表

分析数据

只有 ID 为 1 的玩家在第一天登录后才重新登录,所以答案是 1/3 = 0.33

第一步:选出每个用户id的首次登陆日期

sql 复制代码
select player_id, min(event_date) as login
from activity
group by player_id

第二步:添加连续两次登录的条件

sql 复制代码
select a.event_date fraction
from
    (select player_id, min(event_date) as login
     from activity
     group by player_id) p
        left join activity a
                  on p.player_id=a.player_id and datediff(a.event_date, p.login)=1;

第三步:算出 首次登录的第二天再次登录的玩家的 比率,并四舍五入

sql 复制代码
select round(avg(a.event_date is not null), 2) fraction
from
    (select player_id, min(event_date) as login
     from activity
     group by player_id) p
        left join activity a
 on p.player_id=a.player_id and datediff(a.event_date, p.login)=1;

总结

  • 计算首次日期或最小日期可以使用min()函数
  • 使用DATEDIFF()函数来计算两个日期之间的差值
相关推荐
TheFirst0082 天前
The First项目报告:重塑链上游戏生态,解读B3 Base的双赢局面
游戏
爱写代码的山山2 天前
虚幻蓝图解决抗锯齿方案
游戏·ue5·游戏引擎·虚幻·抗锯齿化
木兰不吃草2 天前
如何在 Mac 上下载安装仙剑游戏仙剑世界?可以通过IPA砸壳包安装非常简单
游戏·macos·ios·游戏程序·mac
Bluesonli3 天前
第 16 天:游戏 UI(UMG)开发,打造主菜单 & 血条!
学习·游戏·ui·ue5·虚幻·unreal engine
Artistation Game4 天前
三、Unity基础(主要框架)
游戏·unity·c#·游戏引擎
Bluesonli6 天前
第 14 天:UE5 C++ 与蓝图(Blueprint)交互!
c++·游戏·ue5·交互·unreal engine
AdSet聚合广告6 天前
游戏APP如何通过精准广告策略实现广告变现收益增长?
人工智能·游戏·搜索引擎·百度·微信小程序·小程序·个人开发
留待舞人归6 天前
【Unity3D优化】AssetBundle的压缩格式优化
游戏·unity·游戏引擎·unity3d
ChiLi_Lin6 天前
游戏内常见加密
游戏
Nicole Potter7 天前
排序之选择排序(C# C++)
数据结构·c++·游戏·c#·排序算法