Thread: Re: ERROR: tuple to be updated was already modified by an operation triggered by the current command
Re: ERROR: tuple to be updated was already modified by an operation triggered by the current command
From
Robins Tharakan
Date:
Hi,
On Thu, 23 Jan 2025 at 19:42, Richard Guo <guofenglinux@gmail.com> wrote:
>
> I came across $SUBJECT, which can be reproduced using the queries
> below.
I also stepped a few times on this the past few days. Here's a smaller repro:
$ grep -l -B100 "tuple to be updated was already modified by an operation triggered by the current command" */source | xargs -i grep Assertion {}
--java.lang.AssertionError: ANALYZE;
--java.lang.AssertionError: ANALYZE( SKIP_LOCKED);
--java.lang.AssertionError: ANALYZE;
--java.lang.AssertionError: ANALYZE( VERBOSE);
--java.lang.AssertionError: ANALYZE( VERBOSE);
Repro SQL
=========
CREATE TEMPORARY TABLE a(b boolean , UNIQUE(b)) ON COMMIT DELETE ROWS ;
CREATE TEMP TABLE d() INHERITS(a) ON COMMIT DROP ;
ANALYSE;
SQL Output
==========
$ psql postgres -f a.sql
CREATE TABLE
CREATE TABLE
psql:a.sql:6: ERROR: tuple to be updated was already modified by an operation triggered by the current command
>
> This error happens in heap_inplace_lock(), and git-bisect says the
> first bad commit is:
>
> a07e03fd8fa7daf4d1356f7cb501ffe784ea6257 is the first bad commit
I also arrived at the same commit.
Checking (914ea1c93c0~0) - 914ea1c93c - fail (1)
Checking (914ea1c93c0~10) - d89335eea6 - fail (1)
Checking (914ea1c93c0~30) - b0a4c3e88b - fail (1)
Checking (914ea1c93c0~70) - 57dec20fd4 - fail (1)
.
.
Checking (914ea1c93c0~1688) - a07e03fd8f - fail (1)
Checking (914ea1c93c0~1689) - dbf3f974ee - pass (0)
Surfacing Commit is a07e03fd8fa7daf4d1356f7cb501ffe784ea6257
Found using SQLancer / creduce.
-
robins
https://robins.in
On Thu, 23 Jan 2025 at 19:42, Richard Guo <guofenglinux@gmail.com> wrote:
>
> I came across $SUBJECT, which can be reproduced using the queries
> below.
I also stepped a few times on this the past few days. Here's a smaller repro:
$ grep -l -B100 "tuple to be updated was already modified by an operation triggered by the current command" */source | xargs -i grep Assertion {}
--java.lang.AssertionError: ANALYZE;
--java.lang.AssertionError: ANALYZE( SKIP_LOCKED);
--java.lang.AssertionError: ANALYZE;
--java.lang.AssertionError: ANALYZE( VERBOSE);
--java.lang.AssertionError: ANALYZE( VERBOSE);
Repro SQL
=========
CREATE TEMPORARY TABLE a(b boolean , UNIQUE(b)) ON COMMIT DELETE ROWS ;
CREATE TEMP TABLE d() INHERITS(a) ON COMMIT DROP ;
ANALYSE;
SQL Output
==========
$ psql postgres -f a.sql
CREATE TABLE
CREATE TABLE
psql:a.sql:6: ERROR: tuple to be updated was already modified by an operation triggered by the current command
>
> This error happens in heap_inplace_lock(), and git-bisect says the
> first bad commit is:
>
> a07e03fd8fa7daf4d1356f7cb501ffe784ea6257 is the first bad commit
I also arrived at the same commit.
Checking (914ea1c93c0~0) - 914ea1c93c - fail (1)
Checking (914ea1c93c0~10) - d89335eea6 - fail (1)
Checking (914ea1c93c0~30) - b0a4c3e88b - fail (1)
Checking (914ea1c93c0~70) - 57dec20fd4 - fail (1)
.
.
Checking (914ea1c93c0~1688) - a07e03fd8f - fail (1)
Checking (914ea1c93c0~1689) - dbf3f974ee - pass (0)
Surfacing Commit is a07e03fd8fa7daf4d1356f7cb501ffe784ea6257
Found using SQLancer / creduce.
-
robins
https://robins.in
Re: ERROR: tuple to be updated was already modified by an operation triggered by the current command
From
Noah Misch
Date:
On Fri, Apr 11, 2025 at 10:18:04PM +0930, Robins Tharakan wrote: > On Thu, 23 Jan 2025 at 19:42, Richard Guo <guofenglinux@gmail.com> wrote: > Repro SQL > ========= > CREATE TEMPORARY TABLE a(b boolean , UNIQUE(b)) ON COMMIT DELETE ROWS ; > CREATE TEMP TABLE d() INHERITS(a) ON COMMIT DROP ; > ANALYSE; Confirmed. Thanks for the report. This is a variant of the bug that commit 7102070 fixed. Key events: - The second CREATE sets relhassubclass=t on "a". - ANALYZE does heap_update() to set relhassubclass=f, since ON COMMIT DROP removed the child. - ON COMMIT DELETE ROWS does an empty index build at end-of-xact, which does an inplace update on the pg_class row of "a". There was no CommandCounterIncrement() since the heap_update(), hence this error. Changing to "ANALYSE a" makes the error go away, because standard_ProcessUtility() does a CCI (added for bug #15631). So I'm inclined to fix that by putting the CCI here for plain "ANALYSE": --- a/src/backend/commands/vacuum.c +++ b/src/backend/commands/vacuum.c @@ -657,6 +657,8 @@ vacuum(List *relations, VacuumParams *params, BufferAccessStrategy bstrategy, if (use_own_xacts) { PopActiveSnapshot(); + /* standard_ProcessUtility() does CCI if !use_own_xacts */ + CommandCounterIncrement(); CommitTransactionCommand(); } else > > This error happens in heap_inplace_lock(), and git-bisect says the > > first bad commit is: > > > > a07e03fd8fa7daf4d1356f7cb501ffe784ea6257 is the first bad commit That commit made it an error to inplace-update an invisible tuple; before that, we silently lost the inplace update.