Re: [BUGS] BUG #14855: index-only scans not used in simple cases
| От | Tom Lane |
|---|---|
| Тема | Re: [BUGS] BUG #14855: index-only scans not used in simple cases |
| Дата | |
| Msg-id | 6164.1508076550@sss.pgh.pa.us обсуждение исходный текст |
| Ответ на | [BUGS] BUG #14855: index-only scans not used in simple cases (andrew@tao11.riddles.org.uk) |
| Список | pgsql-bugs |
andrew@tao11.riddles.org.uk writes:
> Given a unique index on (a) and a (slightly higher cost) index on (a,b), the
> query
> select a,b from sometable where a=123;
> will not do an index-only scan unless the allvisfrac is *exactly* 1.0, and
> in the more normal case where only almost all of the pages are all-visible,
> it will generate the plain index scan on a instead, with the extra heap
> fetch.
> This is obviously because cost_index is using ceil(pages_fetched * (1.0 -
> baserel->allvisfrac)), and since this is a 1-row fetch then pages_fetched is
> still 1 after the adjustment for any value of allvisfrac less than exactly
> 1.0.
One idea is to remove the allvisfrac correction from the pages_fetched
calculation altogether, and instead apply it to the I/O cost numbers
at the end, ie
max_IO_cost *= (1.0 - baserel->allvisfrac);min_IO_cost *= (1.0 - baserel->allvisfrac);
just before the partial_path stanza. While that would improve your
particular complaint I'm not sure if it's a good idea in general.
regards, tom lane
--
Sent via pgsql-bugs mailing list (pgsql-bugs@postgresql.org)
To make changes to your subscription:
http://www.postgresql.org/mailpref/pgsql-bugs
В списке pgsql-bugs по дате отправления: