Thread: support ALTER TABLE DROP EXPRESSION for virtual generated column

hi.

the attached patch is to implement $subject.
the generation expression will be dropped.
the column value previous was NULL will be materialized
based on generation expression.

It seems fairly straightforward:
drop the generation expression in ATExecDropExpression,
and instruct phase 3 to compute the generation expression
and do the table rewrite.

the doc changes:

      <para>
-      This form turns a stored generated column into a normal base column.
-      Existing data in the columns is retained, but future changes will no
-      longer apply the generation expression.
-     </para>
-
-     <para>
-      This form is currently only supported for stored generated columns (not
-      virtual ones).
+      This form turns a generated column into a normal base column.
+      For stored generated column, existing data in the columns is retained;
+      For virtual generated column, it will compute the generation
expression and
+      store the value in the columns. For inheritance hierarchy or
partition hierarchy,
+      the virtual generation expression is computed based on the
child's own generation expression.
+      The future changes will no longer apply the generation expression.
      </para>

Attachment
jian he <jian.universality@gmail.com> writes:
> the attached patch is to implement $subject.

Why would this be a good idea?  I don't see any principled fallback
definition of the column.  (No, "NULL" is not that.)  Certainly we
should support ALTER TABLE DROP COLUMN, but removing the expression
and not providing a substitute seems semantically nonsensical.

            regards, tom lane



Re: support ALTER TABLE DROP EXPRESSION for virtual generated column

From
"David G. Johnston"
Date:
On Wednesday, March 26, 2025, Tom Lane <tgl@sss.pgh.pa.us> wrote:
jian he <jian.universality@gmail.com> writes:
> the attached patch is to implement $subject.

Why would this be a good idea?  I don't see any principled fallback
definition of the column.  (No, "NULL" is not that.)  Certainly we
should support ALTER TABLE DROP COLUMN, but removing the expression
and not providing a substitute seems semantically nonsensical.

I don’t follow how NULL got involved in this discussion. The proposal is basically: turn the virtual expression into an equivalent stored expression, then drop the expression.

I suppose it would make sense to first add an alter table command to allow the user to do a virtual/stored mode swap manually before adding this, which then just becomes a convenient way to specify swap-and-drop as a single command.

David J.

On Thu, Mar 27, 2025 at 11:44 AM David G. Johnston
<david.g.johnston@gmail.com> wrote:
>
> On Wednesday, March 26, 2025, Tom Lane <tgl@sss.pgh.pa.us> wrote:
>>
>> jian he <jian.universality@gmail.com> writes:
>> > the attached patch is to implement $subject.
>>
>> Why would this be a good idea?  I don't see any principled fallback
>> definition of the column.  (No, "NULL" is not that.)  Certainly we
>> should support ALTER TABLE DROP COLUMN, but removing the expression
>> and not providing a substitute seems semantically nonsensical.
>
>
> I don’t follow how NULL got involved in this discussion. The proposal is basically: turn the virtual expression into
anequivalent stored expression, then drop the expression. 
>
This discussion [0] wants to change stored to virtual.

drop the virtual generation, not materialize, column value will be NULL,
but that will not work because commit [1]

So we are either saying that
virtual generation expression cannot be dropped, you can only
substitute another expression
or drop the expression, based on the dropped expression materializing
that column value.

[0]: https://postgr.es/m/CAFCRh-8grTkEy%2B73q79iXB%2Bq%2BsD%3DQkbz-vNAN1KJCF6PRLa%3Dzg%40mail.gmail.com
[1]: https://git.postgresql.org/cgit/postgresql.git/commit/?id=cdc168ad4b22ea4183f966688b245cabb5935d1f