为什么PostgreSQL json_agg()函数不返回空数组?

为什么PostgreSQL json_agg()函数不返回空数组?,第1张

概述我正在使用json_agg函数从PostgreSQL请求返回一个 JSON数组.但是,当没有找到行时,json_agg返回一个空字符串而不是一个空的JSON数组[](如果我理解 json.org则必须使用方括号). 例如: SELECT json_agg(t.*) FROM (SELECT 'test' AS mycol WHERE 1 = 2) AS t ; 返回一个空字符串,而带有’1 = 1 我正在使用Json_agg函数从Postgresql请求返回一个 JSON数组.但是,当没有找到行时,Json_agg返回一个空字符串而不是一个空的JsON数组[](如果我理解 json.org则必须使用方括号).

例如:

SELECT Json_agg(t.*) FROM (SELECT 'test' AS mycol WHERE 1 = 2) AS t ;

返回一个空字符串,而带有’1 = 1’的相同命令返回一个有效的JsON数组(使用Postgresql 9.5测试).

任何的想法?

Json_agg从空集返回null:
select Json_agg(t.*) is nullfrom (select 'test' as mycol where 1 = 2) t ; ?column? ---------- t

如果你想要一个空的Json数组合并它:

select coalesce(Json_agg(t.*),'[]'::Json)from (select 'test' as mycol where 1 = 2) t ; coalesce ---------- []
总结

以上是内存溢出为你收集整理的为什么PostgreSQL json_agg()函数不返回空数组?全部内容,希望文章能够帮你解决为什么PostgreSQL json_agg()函数不返回空数组?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1181612.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存