Re: fill_extraUpdatedCols is done in completely the wrong place

From: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
To: Peter Eisentraut <peter(dot)eisentraut(at)2ndquadrant(dot)com>
Cc: pgsql-hackers(at)lists(dot)postgresql(dot)org
Subject: Re: fill_extraUpdatedCols is done in completely the wrong place
Date: 2020-05-18 17:57:19
Message-ID: 2351.1589824639@sss.pgh.pa.us
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

Peter Eisentraut <peter(dot)eisentraut(at)2ndquadrant(dot)com> writes:
> On 2020-05-08 21:05, Tom Lane wrote:
>> I happened to notice $subject while working on the release notes.
>> AFAICS, it is 100% inappropriate for the parser to compute the
>> set of generated columns affected by an UPDATE, because that set
>> could change before execution. It would be really easy to break
>> this for an UPDATE in a stored rule, for example.

> Do you have a specific situation in mind? How would a rule change the
> set of columns updated by a query? Something involving CTEs? Having a
> test case would be good.

broken-update-rule.sql, attached, shows the scenario I had in mind:
the rule UPDATE query knows nothing of the generated column that
gets added after the rule is stored, so the UPDATE fails to update it.

However, on the way to preparing that test case I discovered that
auto-updatable views have the same disease even when the generated column
exists from the get-go; see broken-updatable-views.sql. In the context
of the existing design, I suppose this means that there needs to be
a fill_extraUpdatedCols call somewhere in the code path that constructs
an auto-update query. But if we moved the whole thing to the executor
then the problem would go away.

I observe also that the executor doesn't seem to need this bitmap at all
unless (a) there are triggers or (b) there are generated columns.
So in a lot of simpler cases, the cost of doing fill_extraUpdatedCols
at either parse or plan time would be quite wasted. That might be a good
argument for moving it to executor start, even though we'd then have
to re-do it when re-using a prepared plan.

regards, tom lane

Attachment Content-Type Size
broken-update-rule.sql text/plain 417 bytes
broken-updatable-views.sql text/plain 224 bytes

In response to

Browse pgsql-hackers by date

  From Date Subject
Next Message Tom Lane 2020-05-18 18:08:53 Re: Why is pq_begintypsend so slow?
Previous Message Ranier Vilela 2020-05-18 17:54:03 Re: Why is pq_begintypsend so slow?