pgsql: Teach planner to short-circuit EXCEPT/INTERSECT with dummy input

From: David Rowley <drowley(at)postgresql(dot)org>
To: pgsql-committers(at)lists(dot)postgresql(dot)org
Subject: pgsql: Teach planner to short-circuit EXCEPT/INTERSECT with dummy input
Date: 2025-10-07 04:18:32
Message-ID: [email protected]
Views: Whole Thread | Raw Message | Download mbox | Resend email
Thread:
Lists: pgsql-committers

Teach planner to short-circuit EXCEPT/INTERSECT with dummy inputs

When either inputs of an INTERSECT [ALL] operator are proven not to return
any results (a dummy rel), then mark the entire INTERSECT operation as
dummy.

Likewise, if an EXCEPT [ALL] operation's left input is proven empty, then
mark the entire operation as dummy.

With EXCEPT ALL, we can easily handle the right input being dummy as
we can return the left input without any processing. That can lead to
significant performance gains during query execution. We can't easily
handle dummy right inputs for EXCEPT (without ALL), as that would require
deduplication of the left input. Wiring up those Paths is likely more
complex than it's worth as the gains during execution aren't that great,
so let's leave that one to be handled by the normal Path generation code.

Author: David Rowley <dgrowleyml(at)gmail(dot)com>
Reviewed-by: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
Discussion: https://postgr.es/m/CAApHDvri53PPF76c3M94_QNWbJfXjyCnjXuj_2=LYM-0m8WZtw@mail.gmail.com

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/9c9d41af4db7e7f81d0f9abc7dc16402386091b0

Modified Files
--------------
src/backend/optimizer/prep/prepunion.c | 63 +++++++++++++++++++++++++
src/test/regress/expected/union.out | 86 +++++++++++++++++++++++++++++++++-
src/test/regress/sql/union.sql | 38 ++++++++++++++-
3 files changed, 185 insertions(+), 2 deletions(-)

Browse pgsql-committers by date

  From Date Subject
Next Message Álvaro Herrera 2025-10-07 08:46:41 pgsql: Fix compile of src/tutorial/funcs.c
Previous Message David Rowley 2025-10-07 01:15:28 pgsql: Fix incorrect targetlist in dummy UNIONs