Re: pgsql: Support partition pruning at execution time
От | Alvaro Herrera |
---|---|
Тема | Re: pgsql: Support partition pruning at execution time |
Дата | |
Msg-id | 20180410151417.zphx6l7t5j4vdgmh@alvherre.pgsql обсуждение исходный текст |
Ответы |
Re: pgsql: Support partition pruning at execution time
Re: pgsql: Support partition pruning at execution time Re: pgsql: Support partition pruning at execution time |
Список | pgsql-hackers |
Changed CC to pgsql-hackers. Tom Lane wrote: > Alvaro Herrera <alvherre@alvh.no-ip.org> writes: > > Frankly, I don't like this. I would rather have an instrument->ntuples2 > > rather than these "divide this by nloops, sometimes" schizoid counters. > > This is already being misused by ON CONFLICT (see "other_path" in > > show_modifytable_info). But it seems like a correct fix would require > > more code. > > The question then becomes whether to put back nfiltered3, or to do > something more to your liking. Think I'd vote for the latter. Doing it properly is not a lot of code actually. Patch attached. ON CONFLICT is not changed by this patch, but that's a straightforward change. Questions: 1. Do we want to back-patch this to 10? I suppose (without checking) that EXPLAIN ANALYZE is already reporting bogus numbers for parallel index-only scans, so I think we should do that. 2. Do we want to revert Andrew's test stabilization patch? If I understand correctly, the problem is the inverse of what was diagnosed: "any running transaction at the time of the test could prevent pages from being set as all-visible". That's correct, but the test doesn't depend on pages being all-visible -- quite the contrary, it depends on the pages NOT being all-visible (which is why the HeapFetches counts are all non-zero). Since the pages contain very few tuples, autovacuum should never process the tables anyway. -- Álvaro Herrera https://www.2ndQuadrant.com/ PostgreSQL Development, 24x7 Support, Remote DBA, Training & Services
Вложения
В списке pgsql-hackers по дате отправления: