MYSQL学习笔记(6)

一些补充知识

replace

replace函数可以将表里面的某个字段值替换成另一个字符,批量操作时直接用sql会比程序来判断执行更快
replace(str,str1,str2);
str:源字符串
str1:待替换字符串
str2:替换后的字符串

例题1.平均播放进度大于60%的视频类别

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

问题分析

(1)播放进度——
播放时长:timestampdiff(second,start_time,end_time) watch_time
视频时长:duration
(timestampdiff(second,start_time,end_time)/duration)*100
(2)如果大于视频时长播放进度记为100%——
if(watch_time>duration,100,(watch_time/duration)*100)
(3)加%拼接:concat((timestampdiff(second,start_time,end_time)/duration)*100,’%’)
(4)保留两位小数:round(,2)
(5)进度大于60%输出——
一开始并不知道replace函数所以在与%拼接前又嵌套了一层筛选,用where筛选了大于60的;
(6)平均——avg();
(7)排序——ORDER BY ;

过程重写

不用replace

SELECT tag,CONCAT(avg_play_progress1,'%') avg_play_progress
FROM
(SELECT tag,round(play_progress,2) avg_play_progress1
FROM
(SELECT t1.tag,
avg(if(watch_time>duration,100,(watch_time/duration)*100)) play_pr
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值