Commit 9d1ac2f5 authored by Tom Lane's avatar Tom Lane

Tweak create_index_paths()'s test for whether to consider a bitmap scan.

Per my note of a couple days ago, create_index_paths would refuse to
consider any path at all for GIN indexes if the selectivity estimate came
out as 1.0; not even if you tried to force it with enable_seqscan.  While
this isn't really a bad outcome in practice, it could be annoying for
testing purposes.  Adjust the test for "is this path only useful for
sorting" so that it doesn't fire on paths with nil pathkeys, which will
include all GIN paths.
parent 1c400d33
...@@ -196,8 +196,8 @@ create_index_paths(PlannerInfo *root, RelOptInfo *rel) ...@@ -196,8 +196,8 @@ create_index_paths(PlannerInfo *root, RelOptInfo *rel)
add_path(rel, (Path *) ipath); add_path(rel, (Path *) ipath);
if (ipath->indexinfo->amhasgetbitmap && if (ipath->indexinfo->amhasgetbitmap &&
ipath->indexselectivity < 1.0 && (ipath->path.pathkeys == NIL ||
!ScanDirectionIsBackward(ipath->indexscandir)) ipath->indexselectivity < 1.0))
bitindexpaths = lappend(bitindexpaths, ipath); bitindexpaths = lappend(bitindexpaths, ipath);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment