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