Greetings, * Andres Freund (and...@anarazel.de) wrote: > On 2020-08-28 11:46:49 -0400, Tom Lane wrote: > > It strikes me that when we are vacuuming a temporary table (which > > necessarily will be one of our own session), we don't really need > > to care what the global xmin horizon is. If we're not inside a > > user transaction block, then there are no tuples in the table that > > could be in-doubt anymore. Neither are there any snapshots in our > > session that could see any dead tuples. Nor do we give a fig what > > other sessions might think of those tuples. So we could just set > > the xmin cutoff as aggressively as possible, which is to say > > equal to the nextXid counter. While vacuuming a temp table is > > perhaps not something people do very often, I think when they do > > do it they would like us to clean out all the dead tuples not just > > some. > > That seems like a good idea.
Agreed. > I've been toying with a patch that introduces more smarts about when a > row is removable, by looking more closely whether a specific row > versions are visible (e.g. in the common case of one old snapshot and > lots of newer rows). But that's orders of magnitude more complicated. So > going for something as simple as this seems like a good idea. I've wondered about this for a long time- very cool that you've found time to actually work on a patch. A couple of different ideas were discussed previously about how to do that kind of a check- mind talking about what method you're using, or perhaps just sharing that patch? :) The potential of such an improvement is huge. Thanks! Stephen
signature.asc
Description: PGP signature