在 PostgreSQL 中,您可能会遇到需要多次调用集合返回函数的情况,每次提供一个数组作为参数。然而,当使用传统的将单个数组传递给函数的方法时,函数可能会被多次调用,导致处理效率低下。
为了解决这个问题,PostgreSQL 9.3 及更高版本提供了 LEFT JOIN LATERAL 。 ..ON 正确的语法。此方法通过执行以下步骤来优化执行:
为了说明这种方法,请考虑以下示例:
SELECT sub.dataid, f.* FROM ( SELECT dataid, array_agg(data) AS arr FROM dataset WHERE dataid = something GROUP BY 1 ) sub LEFT JOIN LATERAL foo(sub.arr) f ON true;
在此示例中,子查询聚合每个 dataid 的数据列,创建一个数组。然后,该数组作为参数传递给 foo() 函数,该函数返回一组增强的数据行。
或者,如果 foo() 函数可能不返回任何行,而您希望保留所有行在连接的左侧,您可以使用 CROSS JOIN LATERAL 或简写语法。
通过利用这种方法,您可以有效地多次调用集合返回函数数组参数,避免不必要的函数调用。
以上是如何在 PostgreSQL 中使用数组参数高效地多次调用返回集合的函数?的详细内容。更多信息请关注PHP中文网其他相关文章!