diff options
author | Tom Lane <tgl@sss.pgh.pa.us> | 2024-10-16 17:36:29 -0400 |
---|---|---|
committer | Tom Lane <tgl@sss.pgh.pa.us> | 2024-10-16 17:36:40 -0400 |
commit | c96de42c4b5f5d7bf785265cf26836326e28c6b6 (patch) | |
tree | ca261462ea452d2f9bba2a57245a6ccb30444adc /src/common/jsonapi.c | |
parent | a7f2f6adc240a2823c2344b89e90bb630dea8803 (diff) | |
download | postgresql-c96de42c4b5f5d7bf785265cf26836326e28c6b6.tar.gz postgresql-c96de42c4b5f5d7bf785265cf26836326e28c6b6.zip |
Further refine _SPI_execute_plan's rule for atomic execution.
Commit 2dc1deaea turns out to have been still a brick shy of a load,
because CALL statements executing within a plpgsql exception block
could still pass the wrong snapshot to stable functions within the
CALL's argument list. That happened because standard_ProcessUtility
forces isAtomicContext to true if IsTransactionBlock is true, which
it always will be inside a subtransaction. Then ExecuteCallStmt
would think it does not need to push a new snapshot --- but
_SPI_execute_plan didn't do so either, since it thought it was in
nonatomic mode.
The best fix for this seems to be for _SPI_execute_plan to operate
in atomic execution mode if IsSubTransaction() is true, even when the
SPI context as a whole is non-atomic. This makes _SPI_execute_plan
have the same rules about when non-atomic execution is allowed as
_SPI_commit/_SPI_rollback have about when COMMIT/ROLLBACK are allowed,
which seems appropriately symmetric. (If anyone ever tries to allow
COMMIT/ROLLBACK inside a subtransaction, this would all need to be
rethought ... but I'm unconvinced that such a thing could be logically
consistent at all.)
For further consistency, also check IsSubTransaction() in
SPI_inside_nonatomic_context. That does not matter for its
one present-day caller StartTransaction, which can't be reached
inside a subtransaction. But if any other callers ever arise,
they'd presumably want this definition.
Per bug #18656 from Alexander Alehin. Back-patch to all
supported branches, like previous fixes in this area.
Discussion: https://postgr.es/m/18656-cade1780866ef66c@postgresql.org
Diffstat (limited to 'src/common/jsonapi.c')
0 files changed, 0 insertions, 0 deletions