Я могу создавать объекты JSON, используя jsonb_build_object
, как мне нужно. Например.
SELECT jsonb_build_object('id', id) FROM (SELECT generate_series(1,3) id) objects;
приводит к
jsonb_build_object
------------------
{"id": 1}
{"id": 2}
{"id": 3}
Но когда я хочу добавить их в массив, они оборачиваются в дополнительный объект, используя имя столбца в качестве ключа:
SELECT jsonb_build_object(
'foo', 'bar',
'collection', jsonb_agg(collection)
)
FROM (
SELECT jsonb_build_object('id', id)
FROM (
SELECT generate_series(1,3) id
) objects
) collection;
приводит к
{"foo": "bar", "collection": [{"jsonb_build_object": {"id": 1}}, {"jsonb_build_object": {"id": 2}}, {"jsonb_build_object": {"id": 3}}]}
Как я могу получить
{"foo": "bar", "collection": [{"id": 1}, {"id": 2}, {"id": 3}]}
вместо?