aboutsummaryrefslogtreecommitdiff
path: root/contrib/postgres_fdw/postgres_fdw.c
diff options
context:
space:
mode:
authorDavid Rowley <drowley@postgresql.org>2022-01-25 21:10:03 +1300
committerDavid Rowley <drowley@postgresql.org>2022-01-25 21:10:03 +1300
commitf9a74c1498d25098606fc5c4621216d38a1cc57d (patch)
treebac9916d8d7cc8b49bffff7c6f0b17614b4d4692 /contrib/postgres_fdw/postgres_fdw.c
parent741bd3293389d451adb91190f84914a59142214f (diff)
downloadpostgresql-f9a74c1498d25098606fc5c4621216d38a1cc57d.tar.gz
postgresql-f9a74c1498d25098606fc5c4621216d38a1cc57d.zip
Consider parallel awareness when removing single-child Appends
8edd0e794 added some code to remove Append and MergeAppend nodes when they contained a single child node. As it turned out, this was unsafe to do when the Append/MergeAppend was parallel_aware and the child node was not. Removing the Append/MergeAppend, in this case, could lead to the child plan being called multiple times by parallel workers when it was unsafe to do so. Here we fix this by just not removing the Append/MergeAppend when the parallel_aware flag of the parent and child node don't match. Reported-by: Yura Sokolov Bug: #17335 Discussion: https://postgr.es/m/b59605fecb20ba9ea94e70ab60098c237c870628.camel%40postgrespro.ru Backpatch-through: 12, where 8edd0e794 was first introduced
Diffstat (limited to 'contrib/postgres_fdw/postgres_fdw.c')
0 files changed, 0 insertions, 0 deletions