首页 >数据库 >mysql教程 >为什么我的函数返回的列在我的 PostgreSQL 查询中串联?

为什么我的函数返回的列在我的 PostgreSQL 查询中串联?

Susan Sarandon
Susan Sarandon原创
2024-12-26 13:27:11692浏览

Why Are My Function's Returned Columns Concatenated in My PostgreSQL Query?

从函数返回的记录显示串联列:揭示原因

在查询中,连接表并从函数检索历史数据,用户可能会遇到从函数返回的列连接成单个字符串的问题。当直接在主查询中使用该函数时,会出现此异常。

了解问题

查询返回多列的函数时,例如:

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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn