summaryrefslogtreecommitdiff
path: root/src/backend/optimizer/geqo/geqo_random.c
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2024-06-07 14:50:09 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2024-06-07 14:50:09 -0400
commit7c4ac652e432f86bd38ce46588dd9a6b04f08595 (patch)
tree1622eff0850cc9703e87cb6fb454d6758be794d2 /src/backend/optimizer/geqo/geqo_random.c
parent1d4ea1376bf0772150903713a51931a225a4c935 (diff)
Reject modifying a temp table of another session with ALTER TABLE.
Normally this case isn't even reachable by non-superusers, since permissions checks prevent naming such a table. However, it is possible to make it happen by altering a parent table whose child is another session's temp table. We definitely can't support any such ALTER that requires modifying the contents of such a table, since we lack access to the other session's temporary-buffer pool. But there seems no good reason to allow it even if it'd only require changing catalog contents. One reason not to allow it is that we'd rather not expose the implementation-dependent behavior of whether a specific ALTER requires touching the table contents. Another is that there may be (in future, even if not today) optimizations that assume that a session's own temp tables won't be modified by other sessions. Hence, add a RELATION_IS_OTHER_TEMP() check to all the places where ALTER TABLE currently does CheckTableNotInUse(). (I looked through all other callers of CheckTableNotInUse(), and they seem OK already.) Per bug #18492 from Alexander Lakhin. Back-patch to all supported branches. Discussion: https://postgr.es/m/18492-c7a2634bf4968763@postgresql.org
Diffstat (limited to 'src/backend/optimizer/geqo/geqo_random.c')
0 files changed, 0 insertions, 0 deletions