使用动态键和 json 值构建 JSON 对象

build JSON object with dynamic keys and json values

我正在尝试使用 postgres 查询构建一个 JSON 对象。我正在寻找的输出类似于下面的对象。属性 "xxx" 和 "yyy" 与日期一样来自列。

{
    "xxx": [ "2018-07-26T11:42:04.514Z", "2018-07-26T11:52:04.514Z"],
    "yyy": [ "2018-07-26T05:42:09.210Z", "2018-07-26T07:22:04.024Z"]
}

我希望通过类似于下面的查询来执行此操作:

SELECT
    json_object(
        array_agg(name),
        array_agg(json_build_array(start_date, end_date)
    )
FROM my_table

my_table table 大致如下所示:

name | start_date                | end_date                 |
-------------------------------------------------------------
xxx  | 2018-07-26T11:42:04.514Z  | 2018-07-26T11:52:04.514Z |
yyy  | 2018-07-26T05:42:09.210Z  | 2018-07-26T07:22:04.024Z |

但是,json_object 只接受文本数组,我似乎找不到替代方案。所以,我得到 ERROR: function json_object(text[], json[]) does not exist。感谢阅读!

使用jsonb_build_array() and json_object_agg().

select json_object_agg(name, jsonb_build_array(start_date, end_date))
from my_table

DbFiddle.