Content-Length: 261869 | pFad | http://github.com/postgrespro/postgres/commit/590fc5d96f8b880fd41c4992dab73ec47f90eca4

B6 Ensure tableoid reads correctly in EvalPlanQual-manufactured tuples. · postgrespro/postgres@590fc5d · GitHub
Skip to content

Commit 590fc5d

Browse files
committed
Ensure tableoid reads correctly in EvalPlanQual-manufactured tuples.
The ROW_MARK_COPY path in EvalPlanQualFetchRowMarks() was just setting tableoid to InvalidOid, I think on the assumption that the referenced RTE must be a subquery or other case without a meaningful OID. However, foreign tables also use this code path, and they do have meaningful table OIDs; so failure to set the tuple field can lead to user-visible misbehavior. Fix that by fetching the appropriate OID from the range table. There's still an issue about whether CTID can ever have a meaningful value in this case; at least with postgres_fdw foreign tables, it does. But that is a different problem that seems to require a significantly different patch --- it's debatable whether postgres_fdw really wants to use this code path at all. Simplified version of a patch by Etsuro Fujita, who also noted the problem to begin with. The issue can be demonstrated in all versions having FDWs, so back-patch to 9.1.
1 parent ae67e81 commit 590fc5d

File tree

1 file changed

+3
-1
lines changed

1 file changed

+3
-1
lines changed

src/backend/executor/execMain.c

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2238,7 +2238,9 @@ EvalPlanQualFetchRowMarks(EPQState *epqstate)
22382238
/* build a temporary HeapTuple control structure */
22392239
tuple.t_len = HeapTupleHeaderGetDatumLength(td);
22402240
ItemPointerSetInvalid(&(tuple.t_self));
2241-
tuple.t_tableOid = InvalidOid;
2241+
/* relation might be a foreign table, if so provide tableoid */
2242+
tuple.t_tableOid = getrelid(erm->rti,
2243+
epqstate->estate->es_range_table);
22422244
tuple.t_data = td;
22432245

22442246
/* copy and store tuple */

0 commit comments

Comments
 (0)








ApplySandwichStrip

pFad - (p)hone/(F)rame/(a)nonymizer/(d)eclutterfier!      Saves Data!


--- a PPN by Garber Painting Akron. With Image Size Reduction included!

Fetched URL: http://github.com/postgrespro/postgres/commit/590fc5d96f8b880fd41c4992dab73ec47f90eca4

Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy