Re: Slow query question

From: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
To: Andrey Povazhnyi <w0rse(dot)t(at)gmail(dot)com>
Cc: pgsql-performance(at)postgresql(dot)org
Subject: Re: Slow query question
Date: 2016-12-06 15:33:55
Message-ID: 26351.1481038435@sss.pgh.pa.us
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-performance

Andrey Povazhnyi <w0rse(dot)t(at)gmail(dot)com> writes:
> We’ve got a strange planner behavior on a query to one of our bigger tables after we upgraded to postgres 9.6.1 recently.

The basic problem with this query is that there are no good alternatives.
The planner believes there are about 53K rows matching the WHERE
condition. (I assume this estimate is roughly in line with reality,
else we have different problems to talk about.) It can either scan down
the "id" index and stop when it finds the 30th row matching WHERE, or
it can use the "symbol" index to read all 53K rows matching WHERE and
then sort them by "id". Neither one of those is going to be speedy;
but the more rows there are matching WHERE, the better the first way
is going to look.

If you're worried about doing this a lot, it might be worth your while
to provide a 2-column index on (source, id) --- in that order --- which
would allow a query plan that directly finds the required 30 rows as
consecutive index entries. Possibly this could replace your index on
"source" alone, depending on how much bigger the 2-col index is and
how many queries have no use for the second column. See
https://www.postgresql.org/docs/current/static/indexes.html
particularly 11.3 - 11.5.

regards, tom lane

In response to

Responses

Browse pgsql-performance by date

  From Date Subject
Next Message Andrey Povazhnyi 2016-12-07 09:51:07 Re: Slow query question
Previous Message Andrey Povazhnyi 2016-12-06 14:35:23 Slow query question