【SQL真题】SQL2:平均播放进度大于60%的视频类别

该博客介绍了两种SQL方法来计算视频平均播放进度,重点关注播放完成率超过60%的视频标签。方法1通过内联视图和聚合函数直接计算,方法2使用CTE(公共表表达式)配合IF函数和AVG函数。两种方法都展示了如何处理时间和比率计算,并按播放进度降序排列结果。

题目:https://www.nowcoder.com/practice/c60242566ad94bc29959de0cdc6d95ef?tpId=268&tqId=2285039&ru=/exam/oj&qru=/ta/sql-factory-interview/question-ranking&sourceUrl=%2Fexam%2Foj%3Fpage%3D1%26tab%3DSQL%25E7%25AF%2587%26topicId%3D268

 方法1:

select
    a.tag,
    avg_play_progress
from  (
    select 
        tag,
        concat(round(avg(if(timestampdiff(second,start_time,end_time)>=duration,
                      1,
                      timestampdiff(second,start_time,end_time)/duration)*100),2),
               "%") as avg_play_progress
    from tb_user_video_log log
    join tb_video_info info
    on log.video_id=info.video_id
    group by tag
) a
where replace(avg_play_progress,"%","")>60
order by avg_play_progress desc

方法2:

#第一步 取出需要的数据,主要是取出每条视频的播放时间
with t as (select tag,TIMESTAMPDIFF(second,start_time,end_time) times,duration d
from tb_user_video_log tl left join tb_video_info ti on tl.video_id = ti.video_id)
#第二步,利用if函数计算每条视频的播放率,在利用avg()函数计算各类视频的平均完播率
select tag, concat(round(avg(if(times <= d,times/d*100,100)),2),'%') avg_play_progress
from t
group by tag
having avg(if(times <= d,times/d*100,100)) > 60
order by avg_play_progress desc
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值