使用 Postgres JSON 数据类型的 Grafana 绘图不起作用

Lor*_*yNZ 7 postgresql json grafana

我正在为我工​​作的公司的内部仪表板设置 Grafana。我们有一个可以跟踪的电话系统,并将指标保存在数据库中。我提取了关键指标并将它们存储在 Postgres 数据库中。这是它的样子:

postgres=# SELECT * FROM phonedata LIMIT 5;
 id |    date    |                                       data                                       
----+------------+----------------------------------------------------------------------------------
 16 | 2019-05-27 | {"avgDuration": "608", "avgQueuetime": "0:02:46.716667", "voicemailCount": "6"}
 17 | 2019-05-26 | {"avgDuration": "676", "avgQueuetime": "None", "voicemailCount": "0"}
 18 | 2019-05-25 | {"avgDuration": "506", "avgQueuetime": "0:01:32.684211", "voicemailCount": "1"}
 19 | 2019-05-24 | {"avgDuration": "540", "avgQueuetime": "0:02:14.784091", "voicemailCount": "11"}
 20 | 2019-05-23 | {"avgDuration": "616", "avgQueuetime": "0:03:09.433962", "voicemailCount": "10"}
(5 rows)
Run Code Online (Sandbox Code Playgroud)

此数据显示“日期”列中显示的日期的统计信息。这一切正常。我有过去 90 天的数据,因此没有缺少数据的问题。

现在我试图在 Grafana 上制作一个图表,显示每天一个电话的平均持续时间,但我无法让它工作。

这是我编写的代码图像和 Grafana 上的图表的链接。StackOverflow 不允许我直接发布图片

https://i.imgur.com/3uQe9t5.png

下面是写出来的代码:

SELECT
    date AS "time",
    data->>'avgDuration'::VARCHAR as "values"
FROM
    phonedata
WHERE
    $__timeFilter(date) AND
    data->>'avgDuration' NOT ilike 'None'
ORDER BY 1
Run Code Online (Sandbox Code Playgroud)

我觉得我已经很接近了,但还没有完全到位。我已经尝试了许多不同的变体,但无法弄清楚。

任何帮助将是巨大的。

谢谢

(我正在运行 Grafana v5.4.2(提交:d812109))

Lor*_*yNZ 5

我已经开始工作了。

我相信这是由时区引起的。我在一些 Grafana 论坛上发现了一个讨论,讨论了一个问题,当返回数据时,它会显示在表格上的所有内容都是“1.56 Tri”。我更改了数据库上的架构,将数据列从 DATE 类型更改为 TIMESTAMPTZ 类型。

这是 PostgreSQL 表现在的样子:

postgres=# SELECT * FROM phonedata LIMIT 5;
 id |          date          |                                   data
----+------------------------+---------------------------------------------------------------------------
  1 | 2019-06-03 00:00:00+12 | {"avgDuration": "543", "avgQueuetime":"0:04:13", "voicemailCount": "7"}
  2 | 2019-06-02 00:00:00+12 | {"avgDuration": "524", "avgQueuetime":"None", "voicemailCount": "2"}
  3 | 2019-06-01 00:00:00+12 | {"avgDuration": "573", "avgQueuetime":"0:03:04", "voicemailCount": "6"}
  4 | 2019-05-31 00:00:00+12 | {"avgDuration": "621", "avgQueuetime":"0:02:14", "voicemailCount": "15"}
  5 | 2019-05-30 00:00:00+12 | {"avgDuration": "729", "avgQueuetime":"0:02:39", "voicemailCount": "5"}
(5 rows)
Run Code Online (Sandbox Code Playgroud)

这就是 Grafana 代码现在的样子:

SELECT
  phonedata.date AS time,
  ((data->>'avgDuration')::NUMERIC) as values
FROM
  phonedata
WHERE
  $__timeFilter(phonedata.date)
Run Code Online (Sandbox Code Playgroud)

这是图形现在的样子:

https://imgur.com/I5cqaMk.png

我还发现如果任何值无法转换为 NUMERIC,图形将不会继续绘制。我会有一天 avgDuration 为“无”,因为那天没有打电话,这会破坏图表。因此,如果它发生在 5 天前,它将绘制前 4 天的图表,在第 5 天失败,并且不会继续到第 6 天。