mirror of
https://github.com/postgres/postgres.git
synced 2025-07-07 00:36:50 +03:00
Properly check index mark/restore in ExecSupportsMarkRestore.
Previously this code assumed that all IndexScan nodes supported mark/restore, which is not true since it depends on optional index AM support functions. This could lead to errors about missing support functions in rare edge cases of mergejoins with no sort keys, where an unordered non-btree index scan was placed on the inner path without a protecting Materialize node. (Normally, the fact that merge join requires ordered input would avoid this error.) Backpatch all the way since this bug is ancient. Per report from Eugen Konkov on irc. Discussion: https://postgr.es/m/87o8jn50be.fsf@news-spur.riddles.org.uk
This commit is contained in:
@ -284,6 +284,8 @@ get_relation_info(PlannerInfo *root, Oid relationObjectId, bool inhparent,
|
||||
info->amhasgettuple = (amroutine->amgettuple != NULL);
|
||||
info->amhasgetbitmap = amroutine->amgetbitmap != NULL &&
|
||||
relation->rd_tableam->scan_bitmap_next_block != NULL;
|
||||
info->amcanmarkpos = (amroutine->ammarkpos != NULL &&
|
||||
amroutine->amrestrpos != NULL);
|
||||
info->amcostestimate = amroutine->amcostestimate;
|
||||
Assert(info->amcostestimate != NULL);
|
||||
|
||||
|
Reference in New Issue
Block a user