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

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

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

select
    tag,
    CONCAT (avg_play_progress, "%")
from
    (
        select
            i.tag as tag,
            round(
                avg(
                    if (
                        timestampdiff (second, l.start_time, l.end_time) > i.duration,
                        100,
                        (
                            timestampdiff (second, l.start_time, l.end_time) / i.duration
                        ) * 100
                    )
                ),
                2
            ) as avg_play_progress
        from
            tb_user_video_log as l
            inner join tb_video_info as i using (video_id)
        group by
            i.tag
        HAVING
            avg_play_progress > 60
        ORDER BY
            avg_play_progress DESC
    ) as t

  • 将两个表连接起来
  • 查询tag,并且计算avg_play_progress
  • 使用having,将不符合要求的分组过滤
  • 将avg_play_progress转化为百分比形式

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-09 11:30
找工作7个月,投了7000封,3段世界五百强实习,才有一个offer,牛油们肯定比我强吧
码农索隆:不对不对不对,实习经历这么厉害,简历也没少投,问题出在哪呢
点赞 评论 收藏
分享
人力小鱼姐:实习经历没有什么含金量,咖啡店员迎宾这种就别写了,其他两段包装一下 想找人力相关的话,总结一下个人优势,结合校园经历里有相关性的部分,加一段自我评价
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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