Re: inefficient/wrong plan cache mode selection for queries with partitioned tables (postgresql 17) - Mailing list pgsql-performance

From Andrei Lepikhov
Subject Re: inefficient/wrong plan cache mode selection for queries with partitioned tables (postgresql 17)
Date
Msg-id ef7eb08a-f336-441c-b2a2-bb0f37389daf@gmail.com
Whole thread Raw
List pgsql-performance
On 12/5/2025 16:04, Maxim Boguk wrote:
> On Mon, May 12, 2025 at 4:48 PM Andrei Lepikhov <lepihov@gmail.com 
>     It is not hard to write such a tiny extension. As I see, the only extra
>     stored "C" procedure is needed to set up force-plan-type flag employing
>     FetchPreparedStatement(). The rest of the code - querying
>     pg_stat_statements and switching between plan types may be written in
>     plpgsql.
> 
>     If I'm not mistaken, it will work with all PG versions that are
>     currently in support. What do you think?
> 
> 
> Such extension would be very useful (and in general - the solution based 
> on the actual execution data - seems more stable/predictable than the 
> plan cost based selection which is currently used by postgresql).
Okay, as far as I can see now, it costs a couple of weeks to develop. It 
would be more profitable in terms of speed and usage in older versions 
than any core patch.
What's more, if, as you predict, it will work, it may provide a 
rationale for opening the entire plan cache for extensions and allow a 
wide audience to impact the extended protocol (and query plans in stored 
procedures) in many curious ways.
As I may envision, a dummy routine providing a link to the 
saved_plan_list will spend a few lines of code. A subscription to cached 
statements may cost more time and effort but seems even more profitable.

-- 
regards, Andrei Lepikhov



pgsql-performance by date:

Previous
From: Tom Lane
Date:
Subject: Re: inefficient/wrong plan cache mode selection for queries with partitioned tables (postgresql 17)
Next
From: Maxim Boguk
Date:
Subject: Re: inefficient/wrong plan cache mode selection for queries with partitioned tables (postgresql 17)