jsonb_agg:避免用 "jsonb_build_object" 包裹的对象
jsonb_agg: Avoid objects wrapped with "jsonb_build_object"
我可以按照我想要的方式使用 jsonb_build_object
创建 JSON 个对象。例如
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}]}
代替?
使用jsonb_agg(collection.jsonb_build_object)
。您也可以使用别名,但关键是 collection
指的是整行,它有一个(单个)jsonb_build_object
命名(默认)列,这是您想要的 JSON聚合。
通过简化和别名,您的查询可以是:
SELECT jsonb_build_object(
'foo', 'bar',
'collection', jsonb_agg(js)
)
FROM generate_series(1,3) id
CROSS JOIN LATERAL jsonb_build_object('id', id) js;
备注:
LATERAL
是隐含的,我只是为了清楚起见才写的
- 在
FROM
子句中使用这样的别名也会创建一个 table 和一个具有相同名称的列别名。所以相当于jsonb_build_object('id', id) AS js(js)
我可以按照我想要的方式使用 jsonb_build_object
创建 JSON 个对象。例如
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}]}
代替?
使用jsonb_agg(collection.jsonb_build_object)
。您也可以使用别名,但关键是 collection
指的是整行,它有一个(单个)jsonb_build_object
命名(默认)列,这是您想要的 JSON聚合。
通过简化和别名,您的查询可以是:
SELECT jsonb_build_object(
'foo', 'bar',
'collection', jsonb_agg(js)
)
FROM generate_series(1,3) id
CROSS JOIN LATERAL jsonb_build_object('id', id) js;
备注:
LATERAL
是隐含的,我只是为了清楚起见才写的- 在
FROM
子句中使用这样的别名也会创建一个 table 和一个具有相同名称的列别名。所以相当于jsonb_build_object('id', id) AS js(js)