]> granicus.if.org Git - postgresql/commit
postgres_fdw: Fix join push down with extensions
authorPeter Eisentraut <peter_e@gmx.net>
Tue, 25 Apr 2017 14:01:59 +0000 (10:01 -0400)
committerPeter Eisentraut <peter_e@gmx.net>
Wed, 26 Apr 2017 13:14:21 +0000 (09:14 -0400)
commit86e640a6941b956d05c0380b754a92050f06bf43
treec749e9340fa854cb53c3bf3b3d543c10bffb2c7e
parente615605239f6df491cd171ed6890b8c70566ef75
postgres_fdw: Fix join push down with extensions

Objects in an extension are shippable to a foreign server if the
extension is part of the foreign server definition's shippable
extensions list.  But this was not properly considered in some cases
when checking whether a join condition can be pushed to a foreign server
and the join condition uses an object from a shippable extension.  So
the join would never be pushed down in those cases.

So, the list of extensions needs to be made available in fpinfo of the
relation being considered to be pushed down before any expressions are
assessed for being shippable.  Fix foreign_join_ok() to do that for a
join relation.

David Rowley and Ashutosh Bapat, per report from David Rowley

reduced version of patch 332bec1e6096679b04ec9717beb44a858495260f for
backpatch to 9.6, first release with join push down
contrib/postgres_fdw/expected/postgres_fdw.out
contrib/postgres_fdw/postgres_fdw.c
contrib/postgres_fdw/sql/postgres_fdw.sql