gpt4 book ai didi

json - 不能使用 jsonb_agg 函数嵌套 PostgreSQL 聚合函数调用

转载 作者:行者123 更新时间:2023-11-29 13:18:33 25 4
gpt4 key购买 nike

我正在尝试让我的查询返回 JSON 以便在 API 中使用。我正在使用 PostGIS 扩展来处理位置信息。 PostGIS 扩展运行良好,不是这个问题的问题。我之所以提到这一点,是因为查询中有与 PostGIS 扩展相关的函数。我有 JSON 文档的这些对象:

  • 主要公司文件(确定)
  • 与公司相关的事件(OK)
  • 与事件相关的日期(* 这是我们遇到问题的地方)
  • 与公司相关的地址(OK)
  • 与公司相关的城市(OK)

这是我的 SQL 语句:

SELECT c.id, c.name, c.website, c.longdescription, c.description, c.email, 
jsonb_agg((SELECT ev FROM (SELECT ev.title, ev.description, ev.longdescription, jsonb_agg((SELECT ed FROM(SELECT ed.startdate, ed.enddate, ed.id WHERE ed.id notnull)ed)) AS dates, ev.id WHERE ev.id notnull)ev)) AS events,
jsonb_agg((SELECT ca FROM (SELECT ct.zip, ca.id, ca.street1, ca.street2, ca.addresstype_id, ST_Y(ca.geopoint::geometry) AS latitude, ST_X(ca.geopoint::geometry) AS longitude WHERE ca.id notnull)ca)) AS addresses
FROM companies c
LEFT JOIN events ev ON ev.company_id = c.id
LEFT JOIN companyaddresses ca ON ca.company_id = c.id
LEFT JOIN cities ct ON ct.id = ca.city_id
LEFT JOIN eventdates ed ON ed.event_id = ev.id
GROUP BY c.id

有什么想法可以让我进行改革而不是使用嵌套函数并仍然得到正确的结果吗?

最佳答案

有问题的行是

jsonb_agg((SELECT ev FROM (SELECT ev.title, ev.description, ev.longdescription, jsonb_agg((SELECT ed FROM(SELECT ed.startdate, ed.enddate, ed.id WHERE ed.id notnull)ed)) AS dates, ev.id WHERE ev.id notnull)ev)) AS events, 

如果您将 jsonb_agg 移动到第二个子查询中,我认为它会起作用。所以改变

jsonb_agg((SELECT ed FROM(SELECT ed.startdate, ed.enddate, ed.id WHERE ed.id notnull)ed)) AS dates

进入

(SELECT jsonb_agg(ed) FROM(SELECT ed.startdate, ed.enddate, ed.id WHERE ed.id notnull)ed) AS dates

我不确定这是否可行,但如果您向 edev 表提供 CREATE 语句,我可以改进它。

关于json - 不能使用 jsonb_agg 函数嵌套 PostgreSQL 聚合函数调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45572853/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com