题解 | #各个视频的平均完播率#

各个视频的平均完播率

https://www.nowcoder.com/practice/96263162f69a48df9d84a93c71045753

select u.video_id,
    round(
        avg(
            case when timestampdiff(second, start_time,end_time) >= duration 
            then 1 else 0
            end)
    ,3) as avg_comp_play_rate
from tb_user_video_log u
left join tb_video_info v
on u.video_id = v.video_id
where date_format(start_time, '%Y') = 2021
and date_format(end_time, '%Y') = 2021
group by u.video_id
order by avg_comp_play_rate desc
  1. timestampdiff(时间单位,开始时间,结束时间) 刚开始开始和结束写反了不知道为什么错
  2. date_format(时间,'%Y-%m-%d') 单引号里的格式可选
  3. 求...率的时候考虑avg()+case when
全部评论

相关推荐

鬼迹人途:你去投一投尚游游戏,服务器一面,第一个图算法,做完了给你一个策略题,你给出方案他就提出低概率问题,答不上当场给你挂
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务