-
Notifications
You must be signed in to change notification settings - Fork 128
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Bug] Specifying TAM for partiotion table #698
Comments
In both cases relkind = 'p' relation will be created. |
To be clear: #695 does not fix this. In only handles how new partition will be created by saving into root partition pg_class.relam, not root partition definition. (this also would fail after 695 merged) |
There are two kinds of partition tables in cloudberry. One is from greenplum, the other one inherits from postgres. The gp-style partition tables appear earlier than pg partition tables. When greenplum upgrade its kernel, the gp-style partition tables tends to implement with the pg partition code. The principle is that the behavior of partition tables try to follow the pg upstream, but also keep the legacy(gp-style) partition behaviors for existing customers. db3=# create table t(i int) partition by range (i) using ao_row distributed by (i) ;
ERROR: specifying a table access method is not supported on a partitioned table The syntax is from pg upstream, and the behavior is exactly the same as pg upstream. The root partition doesn't have access method, so the child can't inherit the access method from its parent. When creating the gp-style partition tables, we try to keep the behavior, to allow the child partition inherits access method and other options from its parent partition. The result is that the root partition table saves its access method in We don't plan to mix all things together to increase complexity. |
Sure, I know.
Thats not true, and this is why this issue is created.
|
The feature was first introduced in postgres 17. Before pg 17, the partition table isn't allowed to have table access method. |
Fixed by #695 |
Cloudberry Database version
No response
What happened
the behavior of creating partitioned table inconsistently handles Table Access Method clause, because of
https://github.com/cloudberrydb/cloudberrydb/blob/main/src/backend/commands/tablecmds.c#L840
if dont really understand this if condition. In my opinion, we should not disallow this. Newly created partitions should inherit partition root TAM, aren't they? So we need a way to specify it.
What you think should happen instead
No response
How to reproduce
Operating System
any
Anything else
No response
Are you willing to submit PR?
Code of Conduct
The text was updated successfully, but these errors were encountered: