Thanks for the report. On Thu, Apr 2, 2026 at 7:43 PM Tom Lane <[email protected]> wrote: > After looking around, I think the likely explanation is that the > concurrently-run alter_table.sql test feels free to mess with the set > of indexes on onek. It doesn't drop onek_unique1, but it does > momentarily rename it: > > ALTER INDEX onek_unique1 RENAME TO attmp_onek_unique1; > ALTER INDEX attmp_onek_unique1 RENAME TO onek_unique1;
Yeah, the fact that it said /* inapplicable */ strongly supports this theory. There's only two ways that can happen, and an index not existing with the expected name is one of them (and the only one that's possible in a query involving only a single table). > I've not looked closely at pg_plan_advice, but if it matches indexes > by name then it seems there's a window here where the advice would > fail to apply. Also, further down we find > > ALTER TABLE onek ADD CONSTRAINT onek_unique1_constraint UNIQUE (unique1); > ALTER INDEX onek_unique1_constraint RENAME TO onek_unique1_constraint_foo; > ALTER TABLE onek DROP CONSTRAINT onek_unique1_constraint_foo; > > which means there's a window there where there are two plausible > indexes to choose. Will test_plan_advice cope if the transient one > is chosen? It's going to be unhappy if the second planning cycle is incapable of choosing the same index that the first planning cycle did. I have to admit that it didn't occur to me that our regression tests would do something like this. I figured they had to be operating on mostly independent objects or things would already be broken, but I failed to consider the possibility that there could be concurrent DDL of a sort that wouldn't affect the normal running of the regression tests but would affect pg_plan_advice. Or at least, if I did ever consider it, I stopped considering it when test_plan_advice appeared to be passing. > So I'm not sure what to do here, but we have a problem. I'm not sure, either, and I agree that we have a problem. I'll give it some more thought tomorrow. -- Robert Haas EDB: http://www.enterprisedb.com
