Re: Postgres 11: Table Partitioning and Primary Keys - Mailing list pgsql-docs

From Michael Paquier
Subject Re: Postgres 11: Table Partitioning and Primary Keys
Date
Msg-id 20190709063448.GB23827@paquier.xyz
Whole thread Raw
In response to Re: Postgres 11: Table Partitioning and Primary Keys  ("David G. Johnston" <david.g.johnston@gmail.com>)
Responses Re: Postgres 11: Table Partitioning and Primary Keys
Re: Postgres 11: Table Partitioning and Primary Keys
Re: Postgres 11: Table Partitioning and Primary Keys
Re: Postgres 11: Table Partitioning and Primary Keys
List pgsql-docs
On Mon, Jul 08, 2019 at 08:12:18PM -0700, David G. Johnston wrote:
> Reads a bit backward.  How about:
>
> "As uniqueness can only be enforced within an individual partition when
> defining a primary key on a partitioned table all columns present in the
> partition key must also exist in the primary key."

Yes, I was not really inspired on this one.

Looking closely at the code in DefineIndex() (and as Rajkumar has
mentioned upthread for unique constraints) this can happen for primary
keys, unique constraints and exclusion constraints.  So we had better
mention all three of them.  I am not sure that we need to be explicit
about the uniqueness part though, let's say the following:
"When defining a primary key, a unique constraint or an exclusion
constraint on a partitioned table, all the columns present in the
constraint definition must be included in the partition key."
--
Michael

Attachment

pgsql-docs by date:

Previous
From: Rajkumar Raghuwanshi
Date:
Subject: Re: Postgres 11: Table Partitioning and Primary Keys
Next
From: Michael Paquier
Date:
Subject: Re: Postgres 11: Table Partitioning and Primary Keys