Re: BUG #17606: There is still some glitch in 3f7323cbb fixing failure of MULTIEXPR_SUBLINK

From: Andre Lin <857348270(at)qq(dot)com>
To: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
Cc: pgsql-bugs <pgsql-bugs(at)lists(dot)postgresql(dot)org>, guofenglinux <guofenglinux(at)gmail(dot)com>
Subject: Re: BUG #17606: There is still some glitch in 3f7323cbb fixing failure of MULTIEXPR_SUBLINK
Date: 2022-09-05 16:50:19
Message-ID: tencent_07224BC44DA2F638D13CDB1C506582EA2806@qq.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-bugs

&gt; After contemplating that for awhile, by far the least painful way
&gt; seems to be to add the subLinkId to struct SubPlan.&nbsp; We can get
&gt; away with that in the back branches as long as we add it at the
&gt; end, since SubPlans don't get recorded in the catalogs.

But let's assume that we manage to verify initplan/subplan by adding
subLinkId to&nbsp;SubPlan, we still have problem. In short, the exact
subqueryid of the new MULTIEXPR&nbsp;Param will be pain in the ass...

Consider the UPDATE sql containing sublinks by order like (subplan,
initplan, subplan, ...)

The existing code "offset = list_length(root-&gt;multiexpr_params)"
will count initplan into "offset", which is correct when first time here,
but it gives wrong subqueryid after...(when the place of initplan should
be "skipped")

In response to

Responses

Browse pgsql-bugs by date

  From Date Subject
Next Message Tom Lane 2022-09-05 17:16:19 Re: BUG #17607: Server process crashes when PLpgSQL function raises error in subtransaction
Previous Message Tom Lane 2022-09-05 16:18:04 Re: BUG #17606: There is still some glitch in 3f7323cbb fixing failure of MULTIEXPR_SUBLINK