]> git.ipfire.org Git - thirdparty/postgresql.git/commit
Support for deparsing of ArrayCoerceExpr node in contrib/postgres_fdw
authorAlexander Korotkov <akorotkov@postgresql.org>
Fri, 18 Jul 2025 07:52:05 +0000 (10:52 +0300)
committerAlexander Korotkov <akorotkov@postgresql.org>
Fri, 18 Jul 2025 07:52:05 +0000 (10:52 +0300)
commit62c3b4cd9ddc6d3066e3f6e43b68fd00c620d9ad
treea91002710828fa10122545bec52c473f777a2048
parentb597ae6cc128b17038d461c5aa426d42f9cc33f9
Support for deparsing of ArrayCoerceExpr node in contrib/postgres_fdw

When using a prepared statement to select data from a PostgreSQL foreign
table (postgres_fdw) with the "field = ANY($1)" expression, the operation
is not pushed down when an implicit type case is applied, and a generic plan
is used.  This commit resolves the issue by supporting the push-down of
ArrayCoerceExpr, which is used in this case.  The support is quite
straightforward and similar to other nods, such as RelabelType.

Discussion: https://postgr.es/m/4f0cea802476d23c6e799512ffd17aff%40postgrespro.ru
Author: Alexander Pyhalov <a.pyhalov@postgrespro.ru>
Reviewed-by: Maxim Orlov <orlovmg@gmail.com>
Reviewed-by: Alexander Korotkov <aekorotkov@gmail.com>
contrib/postgres_fdw/deparse.c
contrib/postgres_fdw/expected/postgres_fdw.out
contrib/postgres_fdw/sql/postgres_fdw.sql