On Thu, 2025-04-24 at 09:48 +0000, PG Doc comments form wrote:
> https://www.postgresql.org/docs/current/ddl-partitioning.html / 5.12.2.3.
> Limitations says:
>
> > To create a unique or primary key constraint on a partitioned table, the
> partition keys must not include any expressions or function calls and the
> constraint's columns must include all of the partition key columns. This
> limitation exists because the individual indexes making up the constraint
> can only directly enforce uniqueness within their own partitions; therefore,
> the partition structure itself must guarantee that there are not duplicates
> in different partitions.
>
> This seems to imply that if I have a table of primary key (a, b, c) in
> b-tree index, then a partition-by-hash method would require this full set of
> columns to be used in order for the constraints to be enforcable. However
> logically this should not be the case - only a hash of a prefix of the
> primary key - eg (a) or (a, b) should be needed to target the same table
> each time and hence get the constraint enforced. Testing this in postgres 16
> seems to show that it does work like this.
From the above:
To create a unique or primary key constraint on a partitioned table,
[...] the constraint's columns must include all of the partition key columns.
You seem to read it the other way around. Your example confirms what the
documentation says.
Yours,
Laurenz Albe