In range partitioning, the table is partitioned into ranges. Each non-overlapped range consists of single or multiple columns representing a single table. For this example, a partition is needed for each quarter that inherits from the main orders table:
data:image/s3,"s3://crabby-images/51e8d/51e8d7842d83c5a974eca22fa43abe13713bf15e" alt=""
However, only the column structure is inherited. You'll need to add indexes, constraints, and adjust permissions on each individual partition to match the master table. The output from psql\d for the table, as shown for the preceding orders table, can be a helpful guide as to what all of those are.
Each partition needs the same primary key:
data:image/s3,"s3://crabby-images/cc51d/cc51dda1fa7267e689cf4d1d20021f86c96a2628" alt=""
That will create an index by orderid as well. A manual index on customerid is also needed:
data:image/s3,"s3://crabby-images/3e13d/3e13d406d5d0ac305a1214401ee4e2a297d80ca8" alt=""
Each order also contains a foreign key constraint to ensure the customer referenced is valid. Those need to be applied to each partition:
data:image/s3,"s3://crabby-images/3fa20/3fa20773b1caa263a2f04adadac282daa9973847" alt=""
The other constraint involved here is actually against the orderliness table, confirming that each order exists. So long as we're careful to never remove an order while working on the partitioning, that constraint can stay in place without modifications. If the table were being dumped and reloaded, you'd have to drop that constraint while that was going on, lest the constraint be violated and cause a problem.