on和where使用的差别

on和where使用的差别

spacer.gifhttps://img1.sycdn.imooc.com//climg/624007af0942b6c109390656.jpg
上面这题想请问一下,求平均进度大于60%的视频


SELECT T2.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 AS T1
LEFT JOIN tb_video_info AS T2
ON T1.video_id=T2.video_id
GROUP BY tag
HAVING REPLACE(avg_play_progress,'%','') > 60
ORDER BY avg_play_progress desc

为什么要用 ON T1.video_id=T2.video_id ,where就没法运行


正在回答 回答被采纳积分+1

登陆购买课程后可参与讨论,去登陆

1回答
DeltaF 2022-03-30 23:46:14

join是表连接,where是条件判断,但如果是比较复杂的sql查询或者是多次连续调用的话就有区别了

where是擅长条件判断,join是擅长表与表之间的联合查询,在多表查询的时候join➕on

问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星

相似问题

登录后可查看更多问答,登录/注册

请稍等 ...
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师