每日一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;
相关推荐
亮子AI2 小时前
【Prisma】如何修复(重建)已经损坏的迁移历史?
数据库·prisma
+VX:Fegn08952 小时前
计算机毕业设计|基于springboot + vue职位管理推荐系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
热爱专研AI的学妹2 小时前
【搭建工作流教程】使用数眼智能 API 搭建 AI 智能体工作流教程(含可视化流程图)
大数据·数据库·人工智能·python·ai·语言模型·流程图
小韩博2 小时前
小迪第42课:PHP应用&MYSQL架构&SQL注入&跨库查询&文件读写&权限操作
sql·mysql·网络安全·架构·php
DBA小马哥3 小时前
国产数据库加速替代Oracle:聚焦信创背景下的平滑迁移与性能突破
数据库·oracle
ok406lhq3 小时前
unity游戏调用SDK支付返回游戏会出现画面移位的问题
android·游戏·unity·游戏引擎·sdk
漂亮的小碎步丶3 小时前
【7】SQL性能优化实践:EXPLAIN解读+慢查询分析+移动代理商结算案例
数据库·sql性能优化
小股虫3 小时前
从Tair虚拟桶到数据库分库分表:解耦逻辑与物理的架构艺术
数据库·架构·解耦
车载测试工程师3 小时前
CAPL学习-CAN相关函数-CANdb API类函数
网络·数据库·学习·capl·canoe
默 语3 小时前
RAG实战:用Java+向量数据库打造智能问答系统
java·开发语言·数据库