From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
---|---|
To: | bokanist(at)gmail(dot)com |
Cc: | pgsql-hackers(at)postgresql(dot)org |
Subject: | Re: [Feature Request] INSERT FROZEN to Optimize Large Cold Data Imports and Migrations |
Date: | 2025-02-13 15:08:44 |
Message-ID: | 3588399.1739459324@sss.pgh.pa.us |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
=?UTF-8?Q?S=C3=A9bastien?= <bokanist(at)gmail(dot)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
From | Date | Subject | |
---|---|---|---|
Next Message | Bertrand Drouvot | 2025-02-13 15:28:47 | Re: Draft for basic NUMA observability |
Previous Message | Oliver Ford | 2025-02-13 15:02:57 | Re: Add RESPECT/IGNORE NULLS and FROM FIRST/LAST options |