Re: BUG #18652: Planner can not find pathkey item to sort for query with expression and expression index
От | Alena Rybakina |
---|---|
Тема | Re: BUG #18652: Planner can not find pathkey item to sort for query with expression and expression index |
Дата | |
Msg-id | 4266190e-a11b-4f0a-b663-e9059aecdc90@postgrespro.ru обсуждение исходный текст |
Ответ на | Re: BUG #18652: Planner can not find pathkey item to sort for query with expression and expression index (Richard Guo <guofenglinux@gmail.com>) |
Ответы |
Re: BUG #18652: Planner can not find pathkey item to sort for query with expression and expression index
|
Список | pgsql-bugs |
On 10.10.2024 14:57, Richard Guo wrote: > On Thu, Oct 10, 2024 at 12:34 PM Tom Lane <tgl@sss.pgh.pa.us> wrote: >> So it's specific to MergeAppend and it's been wrong from day zero. >> That makes me think it's probably not find_computable_ec_member's >> fault directly. Fixing it there might be the most expedient answer, >> but I feel like first we should drill down a bit further to understand >> the root problem. I'm too tired to do more tonight though. > Usually a relation's targetlist should include only Vars and PHVs > during this phase. I think this may be the rationale behind > find_computable_ec_member matching only Vars and quasi-Vars. However, > for a child rel, when we copy the parent's targetlist with appropriate > substitution, we may generate arbitrary expressions, such as an OpExpr > for 'i + 1' in this case. > > We have a note in the comments in set_append_rel_size saying that > > * Code that might be looking at an appendrel child must cope with > * such. > > It seems to me that find_computable_ec_member does not get this memo. > > Alternatively, can we wrap non-var expressions in a childrel's > targetlist into PHVs, so that we do not need special handling for an > appendrel child? I have not tried this though. > To be honest, looking at the MergeAppend processing plan, it’s not entirely clear to me what the functional difference is between set_rel_pathlist and find_computable_ec_member. Both prepare pathkeys , but what the first function doesn't do is what the other one needs to do?Could you explain it to me? -- Regards, Alena Rybakina Postgres Professional
В списке pgsql-bugs по дате отправления: