当前位置: 首页 > news >正文

如何做高网站的浏览量注册登录入口

如何做高网站的浏览量,注册登录入口,商业网站开发实训心得体会范文,湖北网站推广宣传----SQL157 平均播放进度大于60%的视频类别 计算各类视频的平均播放进度,将进度大于60%的类别输出。 注: 播放进度播放时长视频时长*100%,当播放时长大于视频时长时,播放进度均记为100%。 结果保留两位小数,并按播放进…

----SQL157 平均播放进度大于60%的视频类别
计算各类视频的平均播放进度,将进度大于60%的类别输出。
注:
播放进度=播放时长÷视频时长*100%,当播放时长大于视频时长时,播放进度均记为100%。
结果保留两位小数,并按播放进度倒序排序。
输出:
tag|avg_play_progress

表的创建及数据插入:

DROP TABLE IF EXISTS tb_user_video_log, tb_video_info;
CREATE TABLE tb_user_video_log
(id         INT PRIMARY KEY identity,-- '自增ID',uid        INT NOT NULL,-- '用户ID',video_id   INT NOT NULL,-- '视频ID',start_time datetime,-- '开始观看时间',end_time   datetime,-- '结束观看时间',if_follow  TINYINT,-- '是否关注',if_like    TINYINT,-- '是否点赞',if_retweet TINYINT,-- '是否转发',comment_id INT,-- '评论ID'
);CREATE TABLE tb_video_info
(id           INT PRIMARY KEY identity,-- '自增ID',video_id     INT UNIQUE  NOT NULL,-- '视频ID',author       INT         NOT NULL,-- '创作者ID',tag          VARCHAR(16) NOT NULL,-- '类别标签',duration     INT         NOT NULL,-- '视频时长(秒数)',release_time datetime    NOT NULL,-- '发布时间'
);INSERT INTO tb_user_video_log(uid, video_id, start_time, end_time, if_follow, if_like, if_retweet, comment_id)
VALUES (101, 2001, '2021-10-01 10:00:00', '2021-10-01 10:00:30', 0, 1, 1, null),(102, 2001, '2021-10-01 10:00:00', '2021-10-01 10:00:21', 0, 0, 1, null),(103, 2001, '2021-10-01 11:00:50', '2021-10-01 11:01:20', 0, 1, 0, 1732526),(102, 2002, '2021-10-01 11:00:00', '2021-10-01 11:00:30', 1, 0, 1, null),(103, 2002, '2021-10-01 10:59:05', '2021-10-01 11:00:05', 1, 0, 1, null);INSERT INTO tb_video_info(video_id, author, tag, duration, release_time)
VALUES (2001, 901, '影视', 30, '2021-01-01 7:00:00'),(2002, 901, '美食', 60, '2021-01-01 7:00:00'),(2003, 902, '旅游', 90, '2020-01-01 7:00:00');

查询如下:

 select tag,format(CAST(Convert(decimal(18,4),sum(watch_time)*1.0/sum(duration)) * 100 as decimal(10,2)), 'N2') + '%' as avg_play_progressfrom (select tv.tag,datediff(second,start_time,end_time)  as watch_time,tv.durationfrom tb_user_video_log tujoin tb_video_info tvon tu.video_id = tv.video_id)tgroup by tagorder by avg_play_progress desc

使用嵌套方便在写查询时理清思路,可优化查询如下(不嵌套查询):

select tv.tag,format(CAST(avg(iif(datediff(second,start_time,end_time) >= duration,100,Convert(decimal(18,2),datediff(second,start_time,end_time)*1.0/duration)*100)) as decimal(10,2)), 'N2') + '%' as avg_play_progressfrom tb_user_video_log tujoin tb_video_info tvon tu.video_id = tv.video_idgroup by tagorder by avg_play_progress desc

做题小结:
FORMAT函数
FORMAT函数用于将数据格式化为指定的字符串表示形式。它可以应用于各种数据类型,如日期、时间、数值等。
FORMAT函数的基本语法如下:

FORMAT (value, format)

value 是要格式化的表达式或列,format 是定义格式的字符串。
FORMAT函数的格式字符串的确切用法取决于输入表达式的数据类型和所需的输出格式,可以根据实际需求进行调整。
要注意FORMAT函数在处理大量数据时可能会影响性能,如果需要对大型数据集进行格式化,建议在客户端应用程序或报表中进行格式化,而不是在数据库查询中使用FORMAT函数。

【举个🌰】
有查询如下:

select 0.8500 as '转换前', format(cast(0.8500 * 100 as decimal(10,2)), 'N2') + '%' as '转换后'

执行结果:

转换前	转换后
0.8500	85.00%

在此查询中:
① 将待转换的数值使用 CAST 函数将其乘以 100,转换为 DECIMAL(10,2) 类型,结果为 85.00。② 使用 FORMAT 函数将结果格式化为带有两位小数的字符串'N2' 表示将结果作为数字格式化并保留2位小数。具体来说:‘N’ 表示数字格式,‘2’ 表示小数点后保留的位数。
③ 最后在末尾追加百分号 '% '

http://www.yayakq.cn/news/334780/

相关文章:

  • 网站上添加百度地图专业的高端网站制作公司
  • 如何在网站上做跳转代码wordpress版本对应php版本
  • 网站做外链长春长春网站建设
  • 成都网站建设价格表咖啡的营销推广软文
  • 装饰公司看的设计网站网站开发 手机 电脑
  • 网站外链的作用常见的网络推广方式
  • 找工作在什么网站找比较好四川建设网中标公示
  • 网站建设宣传负责网站的建设规划
  • 宁波网站建设建站怎么做石嘴山网站关于两学一做
  • 搜索型网站网站标题长度
  • 网站开发设计选题背景营销网站建设哪家快
  • 温州做网站技术员无锡免费建设网站
  • 太湖县住房和城乡建设网站市建设局生物网站模板
  • 设计购物网站四川住房和城乡建设部网站官网
  • 咸阳网站建设价格wordpress站内搜索框
  • dedecms做手机网站外国做美食视频网站
  • 响应式网站一般怎么设计花2w学ui值得吗
  • 怎样做同性恋女视频网站网站优化推广怎么做
  • 深圳的网站建设公司推荐肇庆网站建设公司哪个好
  • 福建建设执业资格网站报名系统ui设计软件下载
  • 龙华大浪做网站浙江建设厅继续教育网站
  • 苏州网站建设哪家做得好版式设计优秀作品欣赏
  • 阿里云心选建站建一个网站需要多少钱网站怎么做的
  • 长春做网站哪里好前端wordpress后端python
  • 本地网站开发环境搭建wordpress自动刷评论
  • 网站建设入门php做网站教程
  • 北京做erp报价的网站自己建设网站的利弊
  • 企业网站首页设计欣赏wordpress数据名
  • 文化网站前置审批设计网站中企动力优
  • 苏州网站建设报价单微信网页版官网手机版