Re: [Feature Request] INSERT FROZEN to Optimize Large Cold Data Imports and Migrations - Mailing list pgsql-hackers

From Tom Lane
Subject Re: [Feature Request] INSERT FROZEN to Optimize Large Cold Data Imports and Migrations
Date
Msg-id 3588399.1739459324@sss.pgh.pa.us
Whole thread Raw
In response to [Feature Request] INSERT FROZEN to Optimize Large Cold Data Imports and Migrations  (Sébastien <bokanist@gmail.com>)
Responses Re: [Feature Request] INSERT FROZEN to Optimize Large Cold Data Imports and Migrations
List pgsql-hackers
=?UTF-8?Q?S=C3=A9bastien?= <bokanist@gmail.com> writes:
> Implementation details:

>    - A new INSERT FROZEN option could be introduced, similar to COPY FREEZE,
>    allowing direct insertion of tuples in a frozen state.
>    - This would likely require changes in heap storage logic to ensure
>    tuples are written with a frozen XID at insert time.
>    - Consideration should be given to transaction semantics and WAL logging
>    to ensure consistency and crash recovery integrity.

That last is exactly why this won't happen.  A frozen tuple would be
considered committed and visible the instant it appears in the table,
thus completely breaking both atomicity and integrity of the
transaction.

There has been work going on recently to reduce the impact of freezing
massive amounts of data by spreading the work more effectively [1].
I don't say that that particular commit has completely solved the
problem, but I think that continued effort in that direction is more
likely to yield usable results than what you're suggesting.

BTW, this might or might not be usable in your particular workflow,
but: there have long been some optimizations for data load into a
table created in the same transaction.  The idea there is that if the
transaction rolls back, the table will never have been visible to any
other transaction at all, so that maintaining atomicity/integrity of
its contents is moot.

            regards, tom lane

[1] https://git.postgresql.org/gitweb/?p=postgresql.git&a=commitdiff&h=052026c9b



pgsql-hackers by date:

Previous
From: Melanie Plageman
Date:
Subject: Re: BitmapHeapScan streaming read user and prelim refactoring
Next
From: Bertrand Drouvot
Date:
Subject: Re: Draft for basic NUMA observability