题解 | #SQL157平均播放进度大于60%的视频类别#

平均播放进度大于60%的视频类别

https://www.nowcoder.com/practice/c60242566ad94bc29959de0cdc6d95ef

WITH t1 AS (
    SELECT tag,
           ROUND(AVG(IF(
                       TIMESTAMPDIFF(SECOND, start_time, end_time) / duration > 1,
                       100,
                       TIMESTAMPDIFF(SECOND, start_time, end_time) / duration * 100
                   )) OVER (PARTITION BY tag),2) AS avg_play_progress
    FROM tb_user_video_log tu
             LEFT JOIN tb_video_info tv
                       ON tu.video_id = tv.video_id
)
SELECT DISTINCT tag,
    CONCAT (avg_play_progress, '%') AS avg_play_progress
       FROM t1
WHERE avg_play_progress > 60
ORDER BY avg_play_progress DESC;

# 注意一点就是,秒数相减要采用 TIMESTAMPDIFF(单位,start,end)函数

全部评论

相关推荐

05-14 09:24
青岛工学院 C++
点赞 评论 收藏
分享
嵐jlu:我是山川🐔里🐔🧱的,阿里系简历全过; 你这简历一看就还是半成品啊,没有荣誉经历奖项什么的吗?
投递阿里巴巴集团等公司10个岗位
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务