postgresql/contrib
Tom Lane 73f0483fd1 Fix contrib/postgres_fdw to handle multiple join conditions properly.
The previous coding supposed that it could consider just a single join
condition in any one parameterized path for the foreign table.  But in
reality, the parameterized-path machinery forces all join clauses that are
"movable to" the foreign table to be evaluated at that node; including
clauses that we might not consider safe to send across.  Such cases would
result in an Assert failure in an assert-enabled build, and otherwise in
sending an unsafe clause to the foreign server, which might result in
errors or silently-wrong answers.  A lesser problem was that the
cost/rowcount estimates generated for the parameterized path failed to
account for any additional join quals that get assigned to the scan.

To fix, rewrite postgresGetForeignPaths so that it correctly collects all
the movable quals for any one outer relation when generating parameterized
paths; we'll now generate just one path per outer relation not one per join
qual.  Also fix bogus assumptions in postgresGetForeignPlan and
estimate_path_cost_size that only safe-to-send join quals will be
presented.

Based on complaint from Etsuro Fujita that the path costs were being
miscalculated, though this is significantly different from his proposed
patch.
2014-03-07 16:36:50 -05:00
..
adminpack Update copyrights for 2013 2013-01-01 17:15:01 -05:00
auth_delay Limit values of archive_timeout, post_auth_delay, auth_delay.milliseconds. 2012-11-18 17:15:06 -05:00
auto_explain Update copyrights for 2013 2013-01-01 17:15:01 -05:00
btree_gin Throw a useful error message if an extension script file is fed to psql. 2011-10-12 15:45:03 -04:00
btree_gist pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
chkpass Prevent potential overruns of fixed-size buffers. 2014-02-17 11:20:24 -05:00
citext Reduce messages about implicit indexes and sequences to DEBUG1. 2012-07-04 20:35:29 -04:00
cube Fix contrib/cube and contrib/seg to build with bison 3.0. 2013-07-29 10:42:41 -04:00
dblink Fix performance regression in dblink connection speed. 2013-12-07 17:00:10 -08:00
dict_int Update copyrights for 2013 2013-01-01 17:15:01 -05:00
dict_xsyn Update copyrights for 2013 2013-01-01 17:15:01 -05:00
dummy_seclabel Update copyrights for 2013 2013-01-01 17:15:01 -05:00
earthdistance Throw a useful error message if an extension script file is fed to psql. 2011-10-12 15:45:03 -04:00
file_fdw pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
fuzzystrmatch Update copyrights for 2013 2013-01-01 17:15:01 -05:00
hstore Predict integer overflow to avoid buffer overruns. 2014-02-17 09:33:32 -05:00
intagg Throw a useful error message if an extension script file is fed to psql. 2011-10-12 15:45:03 -04:00
intarray Predict integer overflow to avoid buffer overruns. 2014-02-17 09:33:32 -05:00
isn Fix calculation of ISMN check digit. 2014-01-13 15:43:59 +02:00
lo Defend against bad trigger definitions in contrib/lo's lo_manage() trigger. 2013-11-23 22:46:03 -05:00
ltree Predict integer overflow to avoid buffer overruns. 2014-02-17 09:33:32 -05:00
oid2name pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
pageinspect Remove pageinspect--1.0.sql 2013-05-24 08:11:44 -04:00
passwordcheck Update copyrights for 2013 2013-01-01 17:15:01 -05:00
pg_archivecleanup pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
pg_buffercache Split tuple struct defs from htup.h to htup_details.h 2012-08-30 16:52:35 -04:00
pg_freespacemap Throw a useful error message if an extension script file is fed to psql. 2011-10-12 15:45:03 -04:00
pg_standby Prevent potential overruns of fixed-size buffers. 2014-02-17 11:20:24 -05:00
pg_stat_statements Editorialize a bit on new ProcessUtility() API. 2013-04-28 00:18:45 -04:00
pg_test_fsync pg_test_fsync: update output to show usecs/op clearer 2013-05-02 10:27:12 -04:00
pg_test_timing pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
pg_trgm Fix possible buffer overrun in contrib/pg_trgm. 2014-01-13 13:07:13 -05:00
pg_upgrade Fix potential coredump on bad locale value in pg_upgrade. 2014-01-30 18:10:04 -05:00
pg_upgrade_support Update copyrights for 2013 2013-01-01 17:15:01 -05:00
pg_xlogdump Remove broken PGXS code for pg_xlogdump 2013-10-01 17:39:46 -03:00
pgbench Fix progress logging when scale factor is large. 2013-12-12 19:07:53 +09:00
pgcrypto pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
pgrowlocks pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
pgstattuple pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
postgres_fdw Fix contrib/postgres_fdw to handle multiple join conditions properly. 2014-03-07 16:36:50 -05:00
seg Fix contrib/cube and contrib/seg to build with bison 3.0. 2013-07-29 10:42:41 -04:00
sepgsql pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
spi Run pgindent on 9.2 source tree in preparation for first 9.3 2012-06-10 15:20:04 -04:00
sslinfo Lots of doc corrections. 2012-04-23 22:43:09 -04:00
start-scripts Remove dead URL mention in OSX startup script 2013-09-04 17:04:57 -04:00
tablefunc Update copyrights for 2013 2013-01-01 17:15:01 -05:00
tcn Update copyrights for 2013 2013-01-01 17:15:01 -05:00
test_parser Update copyrights for 2013 2013-01-01 17:15:01 -05:00
tsearch2 Update copyrights for 2013 2013-01-01 17:15:01 -05:00
unaccent pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
uuid-ossp Fix quoting in help messages in uuid-ossp extension scripts. 2013-11-22 12:08:10 -05:00
vacuumlo pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
worker_spi Fix some more bugs in signal handlers and process shutdown logic. 2014-02-01 16:21:30 -05:00
xml2 Split tuple struct defs from htup.h to htup_details.h 2012-08-30 16:52:35 -04:00
contrib-global.mk Remove cvs keywords from all files. 2010-09-20 22:08:53 +02:00
Makefile contrib/Makefile also needs updated 2013-02-22 18:56:42 -03:00
README Update contrib/README 2012-04-14 09:29:54 +03:00

The PostgreSQL contrib tree
---------------------------

This subtree contains porting tools, analysis utilities, and plug-in
features that are not part of the core PostgreSQL system, mainly
because they address a limited audience or are too experimental to be
part of the main source tree.  This does not preclude their
usefulness.

User documentation for each module appears in the main SGML
documentation.

When building from the source distribution, these modules are not
built automatically, unless you build the "world" target.  You can
also build and install them all by running "gmake all" and "gmake
install" in this directory; or to build and install just one selected
module, do the same in that module's subdirectory.

Some directories supply new user-defined functions, operators, or
types.  To make use of one of these modules, after you have installed
the code you need to register the new SQL objects in the database
system by executing a CREATE EXTENSION command.  In a fresh database,
you can simply do

    CREATE EXTENSION module_name;

See the PostgreSQL documentation for more information about this
procedure.