远离笨比术 2022-07-03 16:41 采纳率: 72.4%
浏览 22
已结题

MySQL简单编程问题,sum()over()使用

题目中
#问题:计算2021年里每个创作者每月的涨粉率及截止当月的总粉丝量
#注:
#涨粉率=(加粉量 - 掉粉量) / 播放量。结果按创作者ID、总粉丝量升序排序。
#if_follow-是否关注为1表示用户观看视频中关注了视频创作者,为0表示此次互动前后关注状态未发生变化,为2表示本次观看过程中取消了关注。

SELECT 
        author,
            DATE_FORMAT(start_time, '%Y-%m') month,
            ROUND((COUNT(IF(if_follow = 1, 1, NULL)) - COUNT(IF(if_follow = 2, 1, NULL))) / COUNT(start_time), 3) fans_growth_rate,
            sum(sum(case when if_follow = 1 then 1 when if_follow=2 then -1 end)) over(partition by author order by DATE_FORMAT(start_time, '%Y-%m')) total_fans 

    FROM
        _21_tb_user_video_log
    RIGHT JOIN _21_tb_video_info USING (video_id)
    WHERE
        YEAR(start_time) = 2021
    GROUP BY author , month
    ORDER BY author , total_fans;

1.这里上面两个sum的使用是什么作用呢,里面那一层sum()是对其中满足条件的数据筛选处理,那外层是什么作用呢?

2.为什么不能直接里层sum后面加over处理呢?好像sum对数据筛选处理之后,直接用over进行聚类也没啥问题吧

3.还有这里如果用count可以解决吗?为啥不可以,可以的话怎么写呢?

谢谢回答的朋友

  • 写回答

1条回答 默认 最新

  • EA开发-青衫码客 2022-07-08 09:15
    关注

    外层的sum() over() 是开窗组合,作用是做累加求和,即题目要求的 计算截止当月的总粉丝量。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 8月5日
  • 已采纳回答 7月28日
  • 创建了问题 7月3日

悬赏问题

  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)