| From: | Pavel Borisov <pashkin(dot)elfe(at)gmail(dot)com> |
|---|---|
| To: | Alexander Korotkov <aekorotkov(at)gmail(dot)com> |
| Cc: | Justin Pryzby <pryzby(at)telsasoft(dot)com>, Dmitry Koval <d(dot)koval(at)postgrespro(dot)ru>, Alexander Lakhin <exclusion(at)gmail(dot)com>, pgsql-hackers(at)lists(dot)postgresql(dot)org, Tomas Vondra <tomas(dot)vondra(at)enterprisedb(dot)com>, Alvaro Herrera <alvherre(at)alvh(dot)no-ip(dot)org> |
| Subject: | Re: Add SPLIT PARTITION/MERGE PARTITIONS commands |
| Date: | 2026-06-22 10:44:33 |
| Message-ID: | CALT9ZEE9=LbuNx6t1duyXpRx7OM7W5NLirK+5b+8zzV8QrYDmw@mail.gmail.com |
| Views: | Whole Thread | Raw Message | Download mbox | Resend email |
| Thread: | |
| Lists: | pgsql-hackers |
Hi, Alexander!
On Sun, 21 Jun 2026 at 16:11, Alexander Korotkov <aekorotkov(at)gmail(dot)com> wrote:
>
> On Thu, Jun 18, 2026 at 6:49 PM Justin Pryzby <pryzby(at)telsasoft(dot)com> wrote:
> > On Thu, Jun 18, 2026 at 10:31:11AM +0300, Alexander Korotkov wrote:
> > > Pushed with your suggestions accepted.
> >
> > Thanks. When I went back to test this, I merged ~25 partitions that
> > were all on the same tablespace, but the merged table was created on the
> > default tablespace.
> >
> > I tried again with default_tablespace set, but it was ignored. I think
> > that's wrong. It's good to follow the tablespace of the parent table,
> > but if it has no tablespace set, default_tablespace should be obeyed.
> > See surrounding logic in DefineRelation.
> >
> > I see the docs say this:
> > + <command>ALTER TABLE MERGE PARTITION</command> uses the partitioned
> > + table itself as the template to construct the new partition.
> > + The new partition will inherit the same table access method, persistence
> > + type, and tablespace as the partitioned table.
>
> Correct, please see the attached patch, it makes
> createPartitionTable() deal with tablespaces the same was as
> DefineRelation() does.
Thank you for working on this feature!
I've looked into the last v1 patch.
Does it also worth inheriting DefineRelation()'s check and error for
the case if (tablespaceId == GLOBALTABLESPACE_OID)?
A brief look for default_tablespace GUC doesn't reveal a way why it
could not be set to global tablespace in a session.
Best regards,
Pavel Borisov
Supabase
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Önder Kalacı | 2026-06-22 10:57:48 | Re: [PATCH] Improving index selection for logical replication apply with replica identity full |
| Previous Message | Tender Wang | 2026-06-22 10:42:47 | Re: Remove inner joins based on foreign keys |