当前位置: 首页 > 面试题库 >

在MySQL中使用窗口函数移动平均

公冶威
2023-03-14
问题内容

我的数据集如下:

Date              Price     3 Day Moving Average
-------------------------------------------------
2018-08-01         10        
2018-08-02         12       
2018-08-03         11        11    (10+12+11)/3\n
2018-08-04         15        12.67 (12+11+15)/3
2018-08-05         13        13    (11+15+13)/3
2018-08-06         17         ...
2018-08-07         18         鈥�
2018-08-08         20         ..

仅使用MySQL窗口函数可以做到这一点吗?

环境详细信息:

服务器版本:8.0.12 MySQL Community Server-GPL


问题答案:

您可以将Window
Functions与Frames一起使用

SELECT
    Date,
    Price,
    CASE WHEN 
           ROW_NUMBER() OVER (ORDER BY DATE) >= 3 THEN 
             AVG(Price) OVER (ORDER BY Date 
                              ROWS BETWEEN 2 PRECEDING AND 
                                           CURRENT ROW) 
         ELSE NULL 
    END AS avg
FROM yourTable
ORDER BY Date;

DB小提琴演示

细节:

  • 2 PRECEDING表示当前行上方的两行(当前行除外)。我们在上明确定义了升序Date。因此,这意味着两个最接近的日期,低于当前行的日期
  • CURRENT ROW 表示当前行。
  • BETWEEN 使我们能够考虑定义范围内的行(包括边界条件)。
  • 因为,你要移动平均线是null对前两排,我们可以检查此使用Row_number()功能Case .. When


 类似资料:
  • 问题内容: 美好的一天, 我正在使用以下代码来计算9天移动平均线。 但这是行不通的,因为它会在调用限制之前先计算所有返回的字段。换句话说,它将计算该日期之前或等于该日期的所有关闭时间,而不仅仅是最后9个。 因此,我需要从返回的选择中计算出SUM,而不是直接计算出来。 IE浏览器 从SELECT中选择SUM … 现在我将如何去做,这是非常昂贵的还是有更好的方法? 问题答案: 使用类似 内查询返回的所

  • 问题内容: 我有一个很大的PostgreSQL表,可以通过Django访问。因为Django的ORM不支持窗口函数,所以我需要将窗口函数的结果作为常规列烘烤到表中。我想做这样的事情: 但是我明白了 有人可以建议替代方法吗?通过Django的.raw()方法传递窗口函数语法是不合适的,因为它返回RawQuerySet,它不支持其他ORM功能,例如我需要的.filter()。 谢谢。 问题答案: 错误

  • 问题内容: 每当用户接近文档顶部时,我都会尝试向下滚动100px。 当用户接近文档顶部时,我执行了该函数,但是.scrollTo函数不起作用。 我在之前和之后放置了一个警报,以检查它实际上是否是阻止该行的线路,并且只有第一个警报响起,这是代码: 我知道我的jquery页面链接正确,因为我在整个过程中都使用了许多其他jquery函数,而且它们都可以正常工作。我也尝试过从上方删除“ px”,但似乎没有

  • 问题内容: 我需要做类似的事情: 除了,我还需要检索的前20个值的移动平均值。 首选标准SQL,但如有必要,我将使用MySQL扩展。 问题答案: 这只是我的头顶,而且我正要出门,所以未经测试。我也无法想象它会在任何种类的大数据集上表现出色。我确实确认它至少可以正常运行。:)

  • 我有以下数据: 现在我想以这样一种方式过滤数据,我可以删除第6行和第7行,对于特定的uid,我想在代码中只保留一行值为'c' 所以预期的数据应该是: 我使用的窗口函数如下所示:

  • 我试图计算按名称分组的列的季度移动平均线,我定义了一个火花窗口函数规范为 我的数据frame如下所示: