On Wed, 18 Dec 2024 at 23:45, David Rowley <dgrowle...@gmail.com> wrote: > Maybe we need to backpatch passing NULL instead of &TTSOpsMinimalTuple > to ExecBuildGroupingEqual() in BuildTupleHashTableExt(). Something > like the attached patch.
I've attached a more formal patch for this and I've also now done a bit more research and experimentation as to why we didn't notice this for so long. It looks like the non-recursive part of the UNION must use TTSOpsBufferHeapTuple and there must be duplicates. So that basically means you need to select all columns, otherwise, there'd be projection and the slot would be virtual. That boils down to, you need a table without a primary key or any unique constraints, otherwise, you can't get the duplicate value that's required to trigger the Assert failure. I hope the proposed commit message is enough to explain this in enough detail. Of course, there may maybe some other path to trigger this using one of the other users of BuildTupleHashTableExt(). I propose to quickly do a master-only follow-up commit to use the inputOps instead of NULL in BuildTupleHashTableExt (Basically Tom's patch from [1]) Sound ok? David [1] https://postgr.es/m/2543667.1734483...@sss.pgh.pa.us
v1-0001-Fix-Assert-failure-in-WITH-RECURSIVE-UNION-querie.patch
Description: Binary data