hfs*_*hfs 3 postgresql json list jsonb postgresql-9.5
jsonb_build_object我可以按照我想要的方式创建 JSON 对象。例如
SELECT jsonb_build_object('id', id) FROM (SELECT generate_series(1,3) id) objects;
Run Code Online (Sandbox Code Playgroud)
结果是
jsonb_build_object
------------------
{"id": 1}
{"id": 2}
{"id": 3}
Run Code Online (Sandbox Code Playgroud)
但是当我想将它们添加到数组中时,它们被包装在一个附加对象中,并使用列名作为键:
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;
Run Code Online (Sandbox Code Playgroud)
结果是
{"foo": "bar", "collection": [{"jsonb_build_object": {"id": 1}}, {"jsonb_build_object": {"id": 2}}, {"jsonb_build_object": {"id": 3}}]}
Run Code Online (Sandbox Code Playgroud)
我怎样才能得到
{"foo": "bar", "collection": [{"id": 1}, {"id": 2}, {"id": 3}]}
Run Code Online (Sandbox Code Playgroud)
反而?
使用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;
Run Code Online (Sandbox Code Playgroud)
注意事项:
LATERAL是隐含的,我只是为了清楚起见而写它FROM也会创建一个具有相同名称的表和列别名。所以它相当于jsonb_build_object('id', id) AS js(js)| 归档时间: |
|
| 查看次数: |
8812 次 |
| 最近记录: |