远离笨比术 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 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目
  • ¥20 mysql架构,按照姓名分表
  • ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分
  • ¥15 delphi webbrowser组件网页下拉菜单自动选择问题
  • ¥15 linux驱动,linux应用,多线程