Re: ALTER TABLE .. DETACH PARTITION CONCURRENTLY

From: Alvaro Herrera <alvherre(at)alvh(dot)no-ip(dot)org>
To: Amit Langote <amitlangote09(at)gmail(dot)com>
Cc: Justin Pryzby <pryzby(at)telsasoft(dot)com>, Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>, PostgreSQL Hackers <pgsql-hackers(at)lists(dot)postgresql(dot)org>
Subject: Re: ALTER TABLE .. DETACH PARTITION CONCURRENTLY
Date: 2021-04-27 15:47:33
Message-ID: 20210427154733.GA28178@alvherre.pgsql
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On 2021-Apr-27, Amit Langote wrote:

> On Tue, Apr 27, 2021 at 4:34 PM Amit Langote <amitlangote09(at)gmail(dot)com> wrote:

> I think we may need a separate context for partdesc_nodetached, likely
> with the same kludges as rd_pdcxt. Maybe the first problem will go
> away with that as well.

Ooh, seems I completely misunderstood what RelationClose was doing. I
thought it was deleting the whole rd_pdcxt, *including* the "current"
partdesc. But that's not at all what it does: it only deletes the
*children* memcontexts, so the partdesc that is currently valid remains
valid. I agree that your proposed fix appears to be promising, in that
a separate "context tree" rd_pddcxt (?) can be used for this. I'll try
it out now.

> Few other minor things I noticed:
>
> + * Store it into relcache. For snapshots built excluding detached
> + * partitions, which we save separately, we also record the
> + * pg_inherits.xmin of the detached partition that was omitted; this
> + * informs a future potential user of such a cached snapshot.
>
> The "snapshot" in the 1st and the last sentence should be "partdesc"?

Doh, yeah.

> + * We keep two partdescs in relcache: rd_partdesc_nodetached excludes
> + * partitions marked concurrently being detached, while rd_partdesc includes
> + * them.
>
> IMHO, describing rd_partdesc first in the sentence would be better.
> Like: rd_partdesc includes all partitions including any that are being
> concurrently detached, while rd_partdesc_nodetached excludes them.

Makes sense.

--
Álvaro Herrera Valdivia, Chile

In response to

Browse pgsql-hackers by date

  From Date Subject
Next Message Tom Lane 2021-04-27 15:56:22 Re: Since '2001-09-09 01:46:40'::timestamp microseconds are lost when extracting epoch
Previous Message Masahiko Sawada 2021-04-27 15:44:47 Re: Performance degradation of REFRESH MATERIALIZED VIEW