Re: pg_plan_advice
| От | Robert Haas |
|---|---|
| Тема | Re: pg_plan_advice |
| Дата | |
| Msg-id | CA+TgmoZRKFV-rJBgd=Z0w=WF3rSQ1=JJxP8u0NyT_6ow70n6hw@mail.gmail.com обсуждение исходный текст |
| Ответ на | Re: pg_plan_advice (Lukas Fittl <lukas@fittl.com>) |
| Список | pgsql-hackers |
On Thu, Jan 8, 2026 at 2:14 PM Lukas Fittl <lukas@fittl.com> wrote: > On Thu, Jan 8, 2026 at 10:22 AM Robert Haas <robertmhaas@gmail.com> wrote: > > 0004: Comment update, bug fix to cost_index() per comment from Lukas. > > Thanks! I've tested this and this works as expected on current master > with the updated pg_hint_plan code, and checking for tablesample in > the code that sets the mask. Nice! > > How about checking rte->tablesample, as set_rel_pathlist does? > > Yeah, that works - its a bit inconvenient for two reasons, but I don't > think that warrants a redesign: > > 1) get_relation_info_hook doesn't get a RangeTblEntry passed (like > set_rel_pathlist_hook), but that's solvable by looking it up via > simple_rte_array That's a pretty normal thing to have to do in this kind of code, IMHO. > 2) It requires maintaining a special case in the logic that says "make > it parallel", vs the planner that is authoritative (i.e. if we add > more special cases in the future, each extension will have to be > updated to reflect that) IMHO, this is a policy decision by the extension and so the logic belongs in the extension. pg_plan_advice has no similar exception, because it made a different policy decision. Overall, I feel that your experiment here is a pretty compelling argument for committing 0004 (the pgs_mask stuff). I'm not sure it's quite time to do that yet, because maybe there are still some design changes we want to consider for it, or maybe somebody else wants to review first. But even if that patch did nothing other than get rid of lots of complexity and copy-paste in pg_hint_plan, that would be enough to justify this infrastructure. The fact that basically works as intended for both pg_plan_advice and pg_hint_plan, despite them having no common code, is a really good sign, IMHO. -- Robert Haas EDB: http://www.enterprisedb.com
В списке pgsql-hackers по дате отправления: