如何从 PostgreSQL 中的 json 数组查询特定对象

How to query a particular object from a json array in PostgreSQL

我有一个名为 flow_flowrun 的 table 和一个名为 EVENTS 的列下的 json 对象数组,如下所示:

[{"msg": {"urn": "tel:+1238948372", "text": "Would you like to JOIN, reply now", "uuid": "34567a-a634-4c1d-a0a5-56788", "channel": {"name": "*56789", "uuid": "b5bc6e6c-ad18-493f-b28f-744627e739f7"}}, "type": "msg_created", "step_uuid": "a4fg6hh-9419-43a4-tgdv-39a4edc78d69", "created_on": "2015-09-21T06:10:12.217880+00:00"}]

[{"msg": {"urn": "tel:+1294472830", "text": "Hello, how do you feel today", "uuid": "533457-693d-4d67-833c-0d53e7e0ff98", "channel": {"name": "*12345", "uuid": "b5bc6e6c-ad18-493f-b28f-744627e739f7"}}, "type": "msg_created", "step_uuid": "4556763-1f5b-40a4-a29d-5fb1103f4666", "created_on": "2014-02-08T06:04:57.823739+00:00"}]

我想要 运行 一个仅显示 'text' 输出的查询。 所以输出应该是这样的:

留言 你想加入吗,现在回复 你好,今天感觉如何

等等...

我尝试了以下方法但没有成功:

SELECT jsonb_array_elements(fr.events->'msg'->'text') elem
FROM flows_flowrun fr 
SELECT fr.EVENTS ->>'text'
from flows_flowrun fr

感谢期待。

当我 运行 上述查询时,我没有得到任何结果。

您需要先扩展数组并访问其成员:

SELECT jsonb_array_elements(events)->'msg'->>'text'
  FROM flows_flowrun fr