jsonb_agg:避免用" jsonb_build_object"包裹的对象。

时间:2017-04-20 10:28:27

标签: json postgresql list jsonb postgresql-9.5

我可以按照我想要的方式使用jsonb_build_object创建JSON对象。 E.g。

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}]}

代替?

1 个答案:

答案 0 :(得分:2)

使用jsonb_agg(collection.jsonb_build_object)。您也可以使用别名,但重点是collection指的是整个行,它有一个(单个)jsonb_build_object命名(默认情况下)列,它是您要聚合的JSON。 / p>

通过简化和别名,您可以查询:

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子句中
  • 这样的别名会创建一个表&也是一个列别名,具有相同的名称。所以它相当于jsonb_build_object('id', id) AS js(js)
相关问题