用户-视频互动表tb_user_video_log
id | uid | video_id | start_time | end_time | if_follow | if_like | if_retweet | comment_id |
1 | 101 | 2001 | 2021-09-01 10:00:00 |
2021-09-01 10:00:20 |
0 | 1 | 1 | NULL |
2 |
105 |
2002 |
2021-09-10 11:00:00 |
2021-09-10 11:00:30 |
1 | 0 | 1 | NULL |
3 |
101 |
2001 |
2021-10-01 10:00:00 |
2021-10-01 10:00:20 |
1 | 1 | 1 |
NULL |
4 |
102 |
2001 |
2021-10-01 10:00:00 |
2021-10-01 10:00:15 |
0 | 0 | 1 | NULL |
5 |
103 |
2001 |
2021-10-01 11:00:50 |
2021-10-01 11:01:15 |
1 | 1 | 0 | 1732526 |
6 | 106 | 2002 |
2021-10-01 10:59:05 |
2021-10-01 11:00:05 |
2 | 0 | 0 |
NULL |
(uid-用户ID, video_id-视频ID, start_time-开始观看时间, end_time-结束观看时间, if_follow-是否关注, if_like-是否点赞, if_retweet-是否转发, comment_id-评论ID)
短视频信息表tb_video_info
id | video_id | author | tag | duration | release_time |
1 | 2001 | 901 | 影视 | 30 | 2021-01-01 07:00:00 |
2 |
2002 |
901 |
美食 | 60 |
2021-01-01 07:00:00 |
3 |
2003 |
902 |
旅游 | 90 |
2020-01-01 07:00:00 |
4 | 2004 | 902 | 美女 | 90 |
2020-01-01 08:00:00 |
(video_id-视频ID, author-创作者ID, tag-类别标签, duration-视频时长, release_time-发布时间)
问题:计算2021年里每个创作者每月的涨粉率及截止当月的总粉丝量
注:
- 涨粉率=(加粉量 - 掉粉量) / 播放量。结果按创作者ID、总粉丝量升序排序。
- if_follow-是否关注为1表示用户观看视频中关注了视频创作者,为0表示此次互动前后关注状态未发生变化,为2表示本次观看过程中取消了关注。
输出示例:
示例数据的输出结果如下
author | month |
fans_growth_rate |
total_fans |
901 | 2021-09 | 0.500 | 1 |
901 |
2021-10 |
0.250 | 2 |
解释:
示例数据中表tb_user_video_log里只有视频2001和2002的播放记录,都来自创作者901,播放时间在2021年9月和10月;其中9月里加粉量为1,掉粉量为0,播放量为2,因此涨粉率为0.500(保留3位小数);其中10月里加粉量为2,掉粉量为1,播放量为4,因此涨粉率为0.250,截止当前总粉丝数为2。