【发布时间】:2021-06-24 20:09:23
【问题描述】:
我正在将我的面板从使用 SQL 语法(从 InfluxDB 版本 1.X)迁移到新的 influx 语法(InfluxDB 版本 2)。
数据标签存在问题。它包括我用来过滤它的属性。例如,如果我从包含 2 天的范围中选择数据,它会将数据拆分。请看下面的截图:
这完全把图表弄乱了。基本代码如下所示:
from(bucket: "main")
|> range(start: v.timeRangeStart, stop:v.timeRangeStop)
|> filter(fn: (r) =>
r._measurement == "POWER" and
r._field == "value" and
r.device == "living_room"
)
|> aggregateWindow(every: v.windowPeriod, fn: sum)
显然应该只是“POWER”和“CURRENT”。
我尝试了十几种不同的方法,但都想不出一个可行的解决方案。
例如,如果我这样做:
from(bucket: "main")
|> range(start: v.timeRangeStart, stop:v.timeRangeStop)
|> filter(fn: (r) =>
r._measurement == "POWER" and
r._field == "value" and
r.device == "living_room"
)
|> aggregateWindow(every: v.windowPeriod, fn: sum)
|> map(fn: (r) => ({ POWER: r._value }))
它说“数据没有时间字段”。
我也试过
from(bucket: "main")
|> range(start: v.timeRangeStart, stop:v.timeRangeStop)
|> filter(fn: (r) =>
r._measurement == "POWER" and
r._field == "value" and
r.device == "living_room"
)
|> aggregateWindow(every: v.windowPeriod, fn: sum)
|> yield(name: "POWER")
这也不起作用。我尝试了许多其他方法,但均未成功。
我该如何解决这个问题?
【问题讨论】:
标签: grafana influxdb influxdb-2 flux-influxdb