使用array_agg和jsonb_build_对象的Postgresql

使用array_agg和jsonb_build_对象的Postgresql,postgresql,jsonb,array-agg,Postgresql,Jsonb,Array Agg,我正在从各种表构建一个JSON对象。我已经成功地得到了下面的代码,几乎可以做我想做的事情。唯一的问题是聚合数组被设置为另一个对象,我只希望主对象中的项数据指向所选行的数组 SELECT jsonb_build_object('ok',false,'data',f1) FROM (SELECT array_agg(f2) FROM ( SELECT c.catalogid,cl.title,cl.shortname FROM shopmaster.catalog c LE

我正在从各种表构建一个JSON对象。我已经成功地得到了下面的代码,几乎可以做我想做的事情。唯一的问题是聚合数组被设置为另一个对象,我只希望主对象中的项数据指向所选行的数组

SELECT jsonb_build_object('ok',false,'data',f1) FROM 
    (SELECT array_agg(f2) FROM (
    SELECT c.catalogid,cl.title,cl.shortname FROM
    shopmaster.catalog c LEFT JOIN
    shopmaster.catalog_lang cl ON c.catalogid=cl.catalogid LEFT JOIN
    shopmaster.lang l ON cl.langid=l.langid
    WHERE inherit_from=3 AND code='en') f2) f1;
这将返回以下json

{"ok": false, "data": {"array_agg": [{"title": "Vitamins", "catalogid": 6, "shortname": "vit"}, {"title": "Cheese Vitamins", "catalogid": 7, "shortname": "chevit"}, {"title": "fruitveg", "catalogid": 8, "shortname": "fruit and veg"}, {"title": "Magazines", (...)
当我想

{"ok": false, "data": [{"title": "Vitamins", "catalogid": 6, "shortname": "vit"}, {"title": "Cheese Vitamins", "catalogid": 7, "shortname": "chevit"}, {"title": "fruitveg", "catalogid": 8, "shortname": "fruit and veg"}, {"title": "Magazines", (...)

如前一个答案所示,我可以选择命名结果,如
f1.array\u agg
。最后,我像这样使用了
jsonb_agg()
函数

SELECT jsonb_build_object('ok',false,'data',jsonb_agg(f1)) FROM (
    SELECT c.catalogid,cl.title,cl.shortname FROM
    shopmaster.catalog c LEFT JOIN
    shopmaster.catalog_lang cl ON c.catalogid=cl.catalogid LEFT JOIN
    shopmaster.lang l ON cl.langid=l.langid
    WHERE inherit_from=3 AND code='en') f1

从中选择jsonb\u build\u对象('ok',false,'data',f1.array\u agg)…