]> granicus.if.org Git - postgresql/commit
Push scan/join target list beneath Gather when possible.
authorRobert Haas <rhaas@postgresql.org>
Fri, 18 Mar 2016 13:46:40 +0000 (09:46 -0400)
committerRobert Haas <rhaas@postgresql.org>
Fri, 18 Mar 2016 13:50:05 +0000 (09:50 -0400)
commit992b5ba30dcafdc222341505b072a6b009b248a7
treea05302f0aa1af5273f799221e18db5dbadaf8f7c
parent2d8a1e22b109680204cb015a30e5a733a233ed64
Push scan/join target list beneath Gather when possible.

This means that, for example, "SELECT expensive_func(a) FROM bigtab
WHERE something" can compute expensive_func(a) in the workers rather
than the leader if it happens to be parallel-safe, which figures to be
a big win in some practical cases.

Currently, we can only do this if the entire target list is
parallel-safe.  If we worked harder, we might be able to evaluate
parallel-safe targets in the worker and any parallel-restricted
targets in the leader, but that would be more complicated, and there
aren't that many parallel-restricted functions that people are likely
to use in queries anyway.  I think.  So just do the simple thing for
the moment.

Robert Haas, Amit Kapila, and Tom Lane
src/backend/optimizer/plan/createplan.c
src/backend/optimizer/util/pathnode.c