How do I calculate a moving average using MySQL?(如何使用 MySQL 计算移动平均值?)
问题描述
我需要做类似的事情:
SELECT value_column1
FROM table1
WHERE datetime_column1 >= '2009-01-01 00:00:00'
ORDER BY datetime_column1;
除了value_column1
,我还需要检索一个移动平均线<value_column1
的前 20 个值的/a>.
Except in addition to value_column1
, I also need to retrieve a moving average of the previous 20 values of value_column1
.
首选标准 SQL,但如有必要,我将使用 MySQL 扩展.
Standard SQL is preferred, but I will use MySQL extensions if necessary.
推荐答案
这只是我的头顶,我正在出门的路上,所以它未经测试.我也无法想象它会在任何类型的大数据集上表现得很好.我确实确认它至少运行没有错误.:)
This is just off the top of my head, and I'm on the way out the door, so it's untested. I also can't imagine that it would perform very well on any kind of large data set. I did confirm that it at least runs without an error though. :)
SELECT
value_column1,
(
SELECT
AVG(value_column1) AS moving_average
FROM
Table1 T2
WHERE
(
SELECT
COUNT(*)
FROM
Table1 T3
WHERE
date_column1 BETWEEN T2.date_column1 AND T1.date_column1
) BETWEEN 1 AND 20
)
FROM
Table1 T1
这篇关于如何使用 MySQL 计算移动平均值?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何使用 MySQL 计算移动平均值?


基础教程推荐
- 如何在 SQL 中将 Float 转换为 Varchar 2021-01-01
- 二进制文件到 SQL 数据库 Apache Camel 2021-01-01
- 在 MySQL 中:如何将表名作为存储过程和/或函数参数传递? 2021-01-01
- MySQL 中的类型:BigInt(20) 与 Int(20) 2021-01-01
- mysql选择动态行值作为列名,另一列作为值 2021-01-01
- 如何根据该 XML 中的值更新 SQL 中的 XML 2021-01-01
- oracle区分大小写的原因? 2021-01-01
- 什么是 orradiag_<user>文件夹? 2022-01-01
- 表 './mysql/proc' 被标记为崩溃,应该修复 2022-01-01
- 在多列上分布任意行 2021-01-01