Re: bug when apply fast default mechanism for adding new column over domain with default value - Mailing list pgsql-hackers

From Tom Lane
Subject Re: bug when apply fast default mechanism for adding new column over domain with default value
Date
Msg-id 706572.1743555948@sss.pgh.pa.us
Whole thread Raw
In response to Re: bug when apply fast default mechanism for adding new column over domain with default value  (Alexander Lakhin <exclusion@gmail.com>)
Responses Re: bug when apply fast default mechanism for adding new column over domain with default value
List pgsql-hackers
Alexander Lakhin <exclusion@gmail.com> writes:
> I've discovered that 95f650674 introduced a defect similar to bug #18297,
> but this time with DEFAULT. Namely, the following script:
> CREATE TABLE a (aa text);
> CREATE TABLE c (cc text) INHERITS (a);
> CREATE TABLE d (dd text) INHERITS (c, a);
> ALTER TABLE a ADD COLUMN i int DEFAULT 1;

> fails with:
> ERROR:  XX000: tuple already updated by self
> LOCATION:  simple_heap_update, heapam.c:4421

Hmm, yeah.  The failing call is here:

            /* Bump the existing child att's inhcount */
        ...
            CatalogTupleUpdate(attrdesc, &tuple->t_self, tuple);

so I think you're right that that code path is now short a
CommandCounterIncrement() somewhere.  I'll look tomorrow if
nobody beats me to it.

            regards, tom lane



pgsql-hackers by date:

Previous
From: Kwangwon Seo
Date:
Subject: Covering the comparison between date and timestamp, tz, type
Next
From: David Rowley
Date:
Subject: Re: Add mention in docs about locking all partitions for generic plans