From: | Peter Eisentraut <peter(at)eisentraut(dot)org> |
---|---|
To: | Justin Pryzby <pryzby(at)telsasoft(dot)com>, Michael Paquier <michael(at)paquier(dot)xyz> |
Cc: | Soumyadeep Chakraborty <soumyadeep2007(at)gmail(dot)com>, Zhihong Yu <zyu(at)yugabyte(dot)com>, pgsql-hackers(at)postgresql(dot)org, Ashwin Agrawal <ashwinstar(at)gmail(dot)com>, vanjared(at)vmware(dot)com |
Subject: | Re: ALTER TABLE SET ACCESS METHOD on partitioned tables |
Date: | 2024-02-20 14:47:46 |
Message-ID: | d1cb16ec-9af1-4657-81f2-865480d2bd6d@eisentraut.org |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
On 19.07.23 20:13, Justin Pryzby wrote:
> On Thu, Jun 01, 2023 at 08:50:50AM -0400, Michael Paquier wrote:
>> On Wed, May 31, 2023 at 06:35:34PM -0500, Justin Pryzby wrote:
>>> What do you think the comment ought to say ? It already says:
>>>
>>> src/backend/catalog/heap.c- * Make a dependency link to force the relation to be deleted if its
>>> src/backend/catalog/heap.c- * access method is.
>>
>> This is the third location where we rely on the fact that
>> RELKIND_HAS_TABLE_AM() does not include RELKIND_PARTITIONED_TABLE, so
>> it seems worth documenting what we are relying on as a comment? Say:
>> * Make a dependency link to force the relation to be deleted if its
>> * access method is.
>> *
>> * No need to add an explicit dependency for the toast table, as the
>> * main table depends on it. Partitioned tables have a table access
>> * method defined, and RELKIND_HAS_TABLE_AM ignores them.
>
> You said that this location "relies on" the macro not including
> partitioned tables, but I would say the opposite: the places that use
> RELKIND_HAS_TABLE_AM() and do *not* say "or relkind==PARTITIONED_TABLE"
> are the ones that "rely on" that...
>
> Anyway, this updates various comments. No other changes.
It would be helpful if this patch could more extensively document in its
commit message what semantic changes it makes. Various options of
possible behaviors were discussed in this thread, but it's not clear
which behaviors were chosen in this particular patch version.
The general idea is that you can set an access method on a partitioned
table. That much seems very agreeable. But then what happens with this
setting, how can you override it, how can you change it, what happens
when you change it, what happens with existing partitions and new
partitions, etc. -- and which of these behaviors are new and old. Many
things to specify.
From | Date | Subject | |
---|---|---|---|
Next Message | David E. Wheeler | 2024-02-20 14:48:15 | Re: to_regtype() Raises Error |
Previous Message | David E. Wheeler | 2024-02-20 14:44:48 | Re: Patch: Add parse_type Function |