groupArrayMovingAvg

计算输入值的移动平均值。

语法

  1. groupArrayMovingAvg(numbers_for_summing)
  2. groupArrayMovingAvg(window_size)(numbers_for_summing)

该函数可以将窗口大小作为参数。 如果未指定,则该函数的窗口大小等于列中的行数。

参数

  • numbers_for_summing表达式 生成数值数据类型值。
  • window_size — 窗口大小。

返回值

  • 与输入数据大小相同的数组。

对于输入数据类型是Integer,
floating-point,
对应的返回值类型是 Float64
对于输入数据类型是Decimal 返回值类型是 Decimal128

该函数对于 Decimal128 使用 四舍五入到零. 它截断无意义的小数位来保证结果的数据类型。

示例

样表 t:

  1. CREATE TABLE t
  2. (
  3. `int` UInt8,
  4. `float` Float32,
  5. `dec` Decimal32(2)
  6. )
  7. ENGINE = TinyLog
  1. ┌─int─┬─float─┬──dec─┐
  2. 1 1.1 1.10
  3. 2 2.2 2.20
  4. 4 4.4 4.40
  5. 7 7.77 7.77
  6. └─────┴───────┴──────┘

查询:

  1. SELECT
  2. groupArrayMovingAvg(int) AS I,
  3. groupArrayMovingAvg(float) AS F,
  4. groupArrayMovingAvg(dec) AS D
  5. FROM t
  1. ┌─I────────────────────┬─F─────────────────────────────────────────────────────────────────────────────┬─D─────────────────────┐
  2. [0.25,0.75,1.75,3.5] [0.2750000059604645,0.8250000178813934,1.9250000417232513,3.8499999940395355] [0.27,0.82,1.92,3.86]
  3. └──────────────────────┴───────────────────────────────────────────────────────────────────────────────┴───────────────────────┘
  1. SELECT
  2. groupArrayMovingAvg(2)(int) AS I,
  3. groupArrayMovingAvg(2)(float) AS F,
  4. groupArrayMovingAvg(2)(dec) AS D
  5. FROM t
  1. ┌─I───────────────┬─F───────────────────────────────────────────────────────────────────────────┬─D─────────────────────┐
  2. [0.5,1.5,3,5.5] [0.550000011920929,1.6500000357627869,3.3000000715255737,6.049999952316284] [0.55,1.65,3.30,6.08]
  3. └─────────────────┴─────────────────────────────────────────────────────────────────────────────┴───────────────────────┘