从函数返回的记录显示串联列:揭示原因
在查询中,连接表并从函数检索历史数据,用户可能会遇到从函数返回的列连接成单个字符串的问题。当直接在主查询中使用该函数时,会出现此异常。
了解问题
查询返回多列的函数时,例如:
account_servicetier_for_day(acct.accountid, '2014-08-12')
它返回包含所请求数据的记录。但是,当此记录嵌入到另一个查询中时,PostgreSQL 会将其解释为单个连接字符串。
分解函数输出
要解决此问题,用户应提取单个字符串函数记录中的列。在 PostgreSQL 9.3 及更高版本中,这可以使用 JOIN LATERAL 语法来实现,该语法允许将函数无缝集成到 FROM 子句中:
JOIN LATERAL account_servicetier_for_day(a.accountid, '2014-08-12') f ON TRUE
ON TRUE 子句确保左侧的所有行无论返回的行数如何,表都会与函数的结果连接。
在 PostgreSQL 9.2 及更早版本中,提取列数据需要显式子查询:
(SELECT *, account_servicetier_for_day(a.accountid, '2014-08-12') AS rec FROM account_tab a) AS a
这里,子查询将函数调用的结果分配给名为rec的记录。然后,外部查询可以引用记录的列,例如 a.rec.timestamp。
避免 Not In (子查询)
最后,建议避免使用NOT IN(子查询)用于集合排除。相反,更喜欢 NOT EXISTS 子句,它更高效且不易出现性能问题。
以上是为什么我的函数返回的列在我的 PostgreSQL 查询中串联?的详细内容。更多信息请关注PHP中文网其他相关文章!