diff options
author | Michael Paquier <michael@paquier.xyz> | 2018-11-05 11:04:02 +0900 |
---|---|---|
committer | Michael Paquier <michael@paquier.xyz> | 2018-11-05 11:04:02 +0900 |
commit | dc3e436b191a8f8d6f35fad952dd3dc314ccabf9 (patch) | |
tree | 892ae581aef96ed59ec942bea0df3544d5a2bfef /src/backend/executor/nodeProjectSet.c | |
parent | 4bc772e2afa55f26734ff3fbdf27601db030b7e5 (diff) | |
download | postgresql-dc3e436b191a8f8d6f35fad952dd3dc314ccabf9.tar.gz postgresql-dc3e436b191a8f8d6f35fad952dd3dc314ccabf9.zip |
Block creation of partitions with open references to its parent
When a partition is created as part of a trigger processing, it is
possible that the partition which just gets created changes the
properties of the table the executor of the ongoing command relies on,
causing a subsequent crash. This has been found possible when for
example using a BEFORE INSERT which creates a new partition for a
partitioned table being inserted to.
Any attempt to do so is blocked when working on a partition, with
regression tests added for both CREATE TABLE PARTITION OF and ALTER
TABLE ATTACH PARTITION.
Reported-by: Dmitry Shalashov
Author: Amit Langote
Reviewed-by: Michael Paquier, Tom Lane
Discussion: https://postgr.es/m/15437-3fe01ee66bd1bae1@postgresql.org
Backpatch-through: 10
Diffstat (limited to 'src/backend/executor/nodeProjectSet.c')
0 files changed, 0 insertions, 0 deletions