Re: Removing unneeded self joins - Mailing list pgsql-hackers

From Andrei Lepikhov
Subject Re: Removing unneeded self joins
Date
Msg-id df21bd7e-5ec8-4e45-a339-b3a59ec48d1e@gmail.com
Whole thread Raw
In response to Re: Removing unneeded self joins  (Alexander Korotkov <aekorotkov@gmail.com>)
Responses Re: Removing unneeded self joins
List pgsql-hackers
On 23/2/2025 22:15, Alexander Korotkov wrote:
> There is my attempt to implement this approach.  Getting rid of local
> variable (and computation of the same value other way) required to
> change arguments of remove_rel_from_eclass() as well.  I'm going to
> further polish this tomorrow.
I passed through the patch. It works correctly.

Multiple ifs in a single routine is not ideal. I have thought about it 
already, and it seems the remove_rel_from_query needs refactoring: when 
I first reused it for self-join removal, we didn't have the 'ojrelid' 
machinery, and it was implemented smoothly.
Right now, this code contains multiple places where we need to remove 
the outer join relid and separating the removal code for the baserel and 
outer join may simplify the logic and make it safer.
But the way to do it is not apparent now. May be if we implement a new 
technique of query tree reduction, the approach will become more evident.

-- 
regards, Andrei Lepikhov



pgsql-hackers by date:

Previous
From: Tom Lane
Date:
Subject: Re: psql \dh: List High-Level (Root) Tables and Indexes
Next
From: Greg Sabino Mullane
Date:
Subject: Re: psql \dh: List High-Level (Root) Tables and Indexes