繁体   English   中英

无法使用 json_build_object 从 postgreSQL 查询创建大型 json 对象

[英]Unable to create a large json object from a postgreSQL query using json_build_object

我正在尝试使用 json_build_object 从我的查询中创建一个 json 对象,如下所示:

Select json_agg(json_build_object('first_name',first_name,
                                  'last_name',last_name,
                                  'email',email,
                                  'date_joined',date_joined,
                                  'verification_date',verification_date,
                                  'zip_code',zip_code,
                                  'city',city,
                                  'country',country)) 
from users 
WHERE last_name= 'xyz'

json 对象使用上面显示的列数构建得很好,但是当我添加所有列名时,查询会无限期地卡住/挂起,并且不会显示任何错误消息。 我减少了查询中的列数,并返回一个正确的 json 对象。 有没有人对此有任何想法? 谢谢

在省略 json_agg 后我也尝试了查询,但结果仍然相同

我不确定为什么您的查询挂起 - 可能是 args 的数量有限制 - 但由于您正在以一种简单的方式构建每个 JSON 对象(属性名称与列名称相同),请尝试使用row_to_json像这样:

select json_agg(row_to_json(u.*)) from users u WHERE last_name = 'xyz';

无论如何,拥有数十或数百个参数并不好。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM