使用grafana中的变量将InfluxDB查询转换为Postgres查询

问题描述

我有一个在Influx中运行良好的查询:

SELECT delta  FROM "measures"  WHERE  $timeFilter  AND ("operation_id" =~ /^$operationId$/) AND ("meter_id" =~ /^$meterId$/) GROUP BY meter_id

变量operationId和meterId具有“全部”值

在postgres(timescaleDB)中,这等效于我:

SELECT time_bucket('30 minutes',time) AS "time",sum(delta),meter_id
FROM measures
WHERE
  $__timeFilter("time") AND
  operation_id = $operationId AND
  meter_id = $meterId
GROUP BY time,meter_id
ORDER BY time;

由于我每30分钟都有一个值,即使我应该改进此查询,也可以将其视为等效值。

此处显示了graf,但是当我将$ meterId设置为“ all”值时,查询中将出现错误:

pq: syntax error at or near ","

不太冗长。

我尝试对postgres使用相同的正则表达式:

"operation_id" =~ /^$operationId$/

代替

operation_id = $operationId

但它不起作用。

另外,也许与此问题无关的怪异事情是,我对operationId变量具有自动补全功能,而对于meterId变量则没有自动补全功能。

任何想法如何翻译Influx正则表达式?事情是我不太了解这个正则表达式,所以很难翻译。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...