Re: Doc: fix the rewrite condition when executing ALTER TABLE ADD COLUMN

From: Masahiro Ikeda <ikedamsh(at)oss(dot)nttdata(dot)com>
To: Robert Treat <rob(at)xzilla(dot)net>
Cc: pgsql-hackers(at)lists(dot)postgresql(dot)org
Subject: Re: Doc: fix the rewrite condition when executing ALTER TABLE ADD COLUMN
Date: 2025-01-07 02:29:12
Message-ID: dd294b0e70bb7286c8f6aa14a84b377a@oss.nttdata.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On 2025-01-07 06:27, Robert Treat wrote:
> On Mon, Jan 6, 2025 at 3:18 AM Masahiro Ikeda
> <ikedamsh(at)oss(dot)nttdata(dot)com> wrote:
>>
>> On 2025-01-03 01:25, Robert Treat wrote:
>> > On Tue, Dec 3, 2024 at 3:13 AM Masahiro Ikeda
>> > <ikedamsh(at)oss(dot)nttdata(dot)com> wrote:
>> >>
>> >> Hi,
>> >>
>> >> The documentation seems to overlook the rewrite condition
>> >> when executing ALTER TABLE ADD COLUMN.
>> >>
>> >> The current document states that a volatile DEFAULT will
>> >> trigger a rewrite of the table and its indexes. However, the
>> >> table and its indexes will also be rewritten when an IDENTITY
>> >> column is added, or when a column with a domain data type that
>> >> has constraints is added.
>> >>
>> >> What do you think?
>> >>
>> >
>> > We still see a number of people asking (or confused) about table
>> > rewrites when adding columns, so I think the initial tip should
>> > remain, though I think it can be cleaned up a little.
>> >
>> > In the second section (alter_table.sgml) I liked the idea of adding
>> > these additional examples, though I tweaked the wording a bit to
>> > (hopefully) make it a little easier to read.
>> >
>> > Modified patch attached.
>>
>> Thanks! It looks good to me with one minor comment.
>>
>> Is the following intended to remove "However"? It seems that we don't
>> need to modify the lines if the initial tip remains.
>>
>> <para>
>> - However, if the default value is volatile (e.g.,
>> - <function>clock_timestamp()</function>)
>> + If the default value is volatile (e.g.,
>> <function>clock_timestamp()</function>)
>> each row will need to be updated with the value calculated at
>> the
>> time
>>
>
> Technically speaking, because we split the tip into two distinct
> paragraphs, use of the word however would be considered poor grammar,
> though I'll admit I only removed it because it felt superfluous.

OK, thanks for your comments.

Regards,
--
Masahiro Ikeda
NTT DATA CORPORATION

In response to

Browse pgsql-hackers by date

  From Date Subject
Next Message Nathan Bossart 2025-01-07 02:44:37 Re: allow changing autovacuum_max_workers without restarting
Previous Message Hayato Kuroda (Fujitsu) 2025-01-07 01:58:45 RE: initdb -c "track_commit_timestamp=on" crashes in case of debug build