InfluxDB flux 自己寫移動累加function

 

InfluxDB flux 自己寫移動累加function

例如:我要得知 6小時交易量 / 6小時累積雨量 等等 如何Query

不幸的 flux 內建只有移動平均

可以使用

那就自己寫一個

這時候就自己寫一個function
直接看語法:

timedMovingSum = (every, period, column="_value", tables=<-) => tables |> window(every: every, period: period) |> sum(column:column) |> duplicate(column: "_stop", as: "_time") |> window(every: inf)

usage

from(bucket: "quote") |> range(start: v.timeRangeStart, stop:v.timeRangeStop) |> filter(fn: (r) => r._measurement == "realtime" and r.symbol == "${symbolSel}" and r._field == "${col}" ) |> difference() |> difference() |>timedMovingSum(every: 5m, period: 1h) |> movingAverage(n: int(v: strings.replaceAll(v: "${period}", t: "h", u: "") )*12 ) |>map(fn: (r) => ({ r with alias: "${period}" }))

Parameters

every

The frequency of time windows.

Data type: Duration

period

The length of each averaged time window. A negative duration indicates start and stop boundaries are reversed.

Data type: Duration

column

The column used to compute the moving sum. Defaults to “_value”.

Data type: String


md

留言

這個網誌中的熱門文章

Google Map 單車路徑計算坡度和角度小工具

angular 如何Http 如何設定 CORS (Cross-Origin Resource Sharing)

10月24日 「方程式編輯器」讓你用Word打數學算式、根號、平方