Re: Removing unneeded self joins
От | Alexander Korotkov |
---|---|
Тема | Re: Removing unneeded self joins |
Дата | |
Msg-id | CAPpHfduAbWu1z+aC0tmS6mP3spqfATZs860u8RKv_jZvriKVQg@mail.gmail.com обсуждение исходный текст |
Ответ на | Re: Removing unneeded self joins (Michael Paquier <michael@paquier.xyz>) |
Список | pgsql-hackers |
Hi, Michael! On Fri, Jun 27, 2025 at 3:26 AM Michael Paquier <michael@paquier.xyz> wrote: > On Thu, Jun 26, 2025 at 08:54:55AM +0200, Andrei Lepikhov wrote: > > Before diving into the pg_hint_plan code, I wonder why you don't have > > similar issues with the remove_useless_joins. We intentionally designed SJE > > coupled with the left-join removal feature to avoid such type of complaints: > > > > CREATE TABLE test (x integer PRIMARY KEY); > > EXPLAIN (COSTS OFF) > > SELECT t1.* FROM test t1 LEFT JOIN test t2 ON (t1.x=t2.x); > > > > /* > > QUERY PLAN > > --------------------- > > Seq Scan on test t1 > > (1 row) > > */ > > > > It seems that this join removal is also beyond the pg_hint_plan control ... > > Yeah, remove_useless_joins() has been around since the 9.0 ages as far > as I know, and it's not bothered the module much in the tests because > we have unlikely relied on it. > > For now the trick I am going to rely on is just disable > enable_self_join_elimination in the test paths where I rely on the > same relation and self joins to keep the plans of the regression tests > stable. This stuff could create separate relations, but then with > back-patching in mind that's going to be just extra conflict noise, > which is always annoying when dealing with plan outputs. We've done > that in the past with max_parallel_workers_per_gather or jit, to keep > the expected plans stable. > > The point regarding the search join hook may stand, though. Perhaps > somebody should check if we're still OK with this change in the > context of the self-join work. I tend to think that we are and I > agree that removing the joins when calling the hook can show benefits, > but it may be surprising and users tend to be very noisy with plan > stability, particularly if some of the FROM aliases get silenced by > the backend without the module knowing about that. At least there is > the trick with SET enable_self_join_elimination available as a last > resort method. One thing I could additionally propose it to add hook, which gets called before self-join elimination. If pg_hint_plan will use this hook, it could prevent self-join elimination or track this fact in its data structures. On the other hand we didn't do similar thing for remove_useless_joins(). Not sure if it's justified now. ------ Regards, Alexander Korotkov Supabase
В списке pgsql-hackers по дате отправления: