Amit Langote <amitlangot...@gmail.com> writes: > Thanks for pointing out the hole in the current handling of > CachedPlan->stmt_list. You're right that the approach of preserving > the list structure while replacing its contents in-place doesn’t hold > up when the rewriter adds or removes statements dynamically. There > might be other cases that neither of us have tried. I don’t think > that mechanism is salvageable.
> To address the issue without needing a full revert, I’m considering > dropping UpdateCachedPlan() and removing the associated MemoryContext > dance to preserve CachedPlan->stmt_list structure. Instead, the > executor would replan the necessary query into a transient list of > PlannedStmts, leaving the original CachedPlan untouched. That avoids > mutating shared plan state during execution and still enables deferred > locking in the vast majority of cases. Yeah, I think messing with the CachedPlan is just fundamentally wrong. It breaks the invariant that the executor should not scribble on what it's handed --- maybe not as obviously as some other cases, but it's still not a good design. I kind of feel that we ought to take two steps back and think about what it even means to have a generic plan in this situation. Perhaps we should simply refuse to use that code path if there are prunable partitioned tables involved? > Let me know what you think -- I’ll hold off on posting a revert or a > replacement until we’ve agreed on the path forward. I had not looked at 525392d57 in any detail before (the claim in the commit message that I reviewed it is a figment of someone's imagination). Now that I have, I'm still going to argue for revert. Aside from the points above, I really hate what's been done to the fundamental executor APIs. The fact that ExecutorStart callers have to know about this is as ugly as can be. I also don't like the fact that it's added overhead in cases where there can be no benefit (notice that my test case doesn't even involve a partitioned table). I still like the core idea of deferring locking, but I don't like anything about this implementation of it. It seems like there has to be a better and simpler way. regards, tom lane