Re: BUG #19439: pg_stat_xact_user_tables stat not currect during the transaction

From: Xuneng Zhou <xunengzhou(at)gmail(dot)com>
To: klemen(dot)kobau(at)gmail(dot)com, pgsql-bugs(at)lists(dot)postgresql(dot)org
Subject: Re: BUG #19439: pg_stat_xact_user_tables stat not currect during the transaction
Date: 2026-03-27 02:15:27
Message-ID: CABPTF7Wx=WTHa67PJUnH8VaJf-svrcFjt1ZgOVrqWzfgwDuMCA@mail.gmail.com
Views: Whole Thread | Raw Message | Download mbox | Resend email
Thread:
Lists: pgsql-bugs

Hi klemen,

Thanks for the report.

On Fri, Mar 27, 2026 at 5:36 AM PG Bug reporting form
<noreply(at)postgresql(dot)org> wrote:
>
> The following bug has been logged on the website:
>
> Bug reference: 19439
> Logged by: klemen kobau
> Email address: klemen(dot)kobau(at)gmail(dot)com
> PostgreSQL version: 18.0
> Operating system: Linux (EndeavorOS)
> Description:
>
> I am running postgres:18.0 in a docker container, the configuration is as
> follows:
>
> postgres:
> image: postgres:18.0
> command: [
> "postgres",
> "-N", "200",
> "-c", "max_prepared_transactions=100",
> "-c", "wal_level=logical",
> "-c", "max_wal_senders=10",
> "-c", "max_replication_slots=20",
> "-c", "wal_keep_size=10",
> "-c", "max_slot_wal_keep_size=1024"
> ]
> environment:
> POSTGRES_USER: postgres
> POSTGRES_PASSWORD: postgres
> POSTGRES_DB: postgres
> TZ: UTC
> PGTZ: UTC
> ports:
> - 5432:5432
> volumes:
> - postgres_data:/var/lib/postgresql
>
> I use psql version 18.3.
>
> I run the following:
>
> psql -h localhost -p 5432 -U postgres -d postgres -c "
> -- Transaction 1: insert 1 row, check stats, commit
> BEGIN;
> CREATE TABLE IF NOT EXISTS temp.xact_test (id serial PRIMARY KEY, val text);
> INSERT INTO temp.xact_test (val) VALUES ('a');
> SELECT relname, n_tup_ins FROM pg_stat_xact_user_tables WHERE relname =
> 'xact_test';
> COMMIT;
>
> -- Transaction 2: insert 1 row, check stats
> BEGIN;
> INSERT INTO temp.xact_test (val) VALUES ('b');
> SELECT relname, n_tup_ins FROM pg_stat_xact_user_tables WHERE relname =
> 'xact_test';
> ROLLBACK;
>
> -- Cleanup
> DROP TABLE temp.xact_test;
> "
>
> And the output is
>
> BEGIN
> CREATE TABLE
> INSERT 0 1
> relname | n_tup_ins
> -----------+-----------
> xact_test | 1
> (1 row)
>
> COMMIT
> BEGIN
> INSERT 0 1
> relname | n_tup_ins
> -----------+-----------
> xact_test | 2
> (1 row)
>
> ROLLBACK
> DROP TABLE

I can also reproduce this behavior on HEAD.

> This is not what I would expect from reading
> https://www.postgresql.org/docs/current/monitoring-stats.html#MONITORING-STATS-VIEWS,
> where it states
>
> > A transaction can also see its own statistics (not yet flushed out to the
> shared memory statistics) in the views pg_stat_xact_all_tables,
> pg_stat_xact_sys_tables, pg_stat_xact_user_tables, and
> pg_stat_xact_user_functions. These numbers do not act as stated above;
> instead they update continuously throughout the transaction.
>
> based on this, I would expect that the numbers are updated each time an
> insert happens and that they are isolated per transaction.
>

This snippet of the doc feels somewhat ambiguous. The current behavior
does not seem fully consistent with wording such as “throughout the
transaction.” It also seems more appropriate for these table views to
reflect stats within their own scopes, rather than cumulative values
spanning txn boundaries.

--
Best,
Xuneng

In response to

Responses

Browse pgsql-bugs by date

  From Date Subject
Next Message Hayato Kuroda (Fujitsu) 2026-03-27 04:33:55 RE: [BUG] Assert failure in ReorderBufferReturnTXN during logical decoding due to leaked specinsert change
Previous Message Tender Wang 2026-03-27 01:19:29 Re: BUG #19435: Error: "No relation entry for relid 2" Triggered by Complex Join with Self-Referencing Tables