每日一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;
相关推荐
e***096几秒前
postgresql链接详解
数据库·postgresql
踢球的打工仔4 分钟前
mysql数据表的基本操作
数据库·mysql
踢球的打工仔10 分钟前
mysql链接(2)
数据库·mysql
专注API从业者11 分钟前
构建分布式京东商品数据采集器:基于微服务的架构设计与实现
数据结构·数据库·分布式·微服务·架构
h***015413 分钟前
MySQL数据库的数据文件保存在哪?MySQL数据存在哪里
数据库·mysql
k***216016 分钟前
MySQL 批量插入详解:快速提升大数据导入效率的实战方法
大数据·数据库·mysql
chenyuhao202421 分钟前
MySQL事务
开发语言·数据库·c++·后端·mysql
l***370930 分钟前
Spring Boot中集成MyBatis操作数据库详细教程
数据库·spring boot·mybatis
t***p93532 分钟前
MySql中的事务、MySql事务详解、MySql隔离级别
数据库·mysql·adb
q***876036 分钟前
Nginx之rewrite重写功能
数据库·mysql·nginx