Re: performance question (something to do w/ parameterized - Mailing list pgsql-performance

From Tom Lane
Subject Re: performance question (something to do w/ parameterized
Date
Msg-id 29345.1147118920@sss.pgh.pa.us
Whole thread Raw
In response to Re: performance question (something to do w/ parameterized  (Jeffrey Tenny <jeffrey.tenny@comcast.net>)
Responses Re: performance question (something to do w/ parameterized  (Jeffrey Tenny <jeffrey.tenny@comcast.net>)
List pgsql-performance
Jeffrey Tenny <jeffrey.tenny@comcast.net> writes:
> Well, since I don't know the exact parameter values, just substituting
> 1-650 for $1-$650, I get:

>   Index Scan using testindex2 on x  (cost=0.00..34964.52 rows=1503
> width=16) (actual time=0.201..968.252 rows=677 loops=1)
>     Filter: ((f = 1) OR (f = 2) OR (f = 3) OR (f = 4) ...

> So index usage is presumably good on this one.

No, that's not a very nice plan at all --- the key thing to notice is
it says Filter: not Index Cond:.  What you've actually got here is a
full-index scan over testindex2 (I guess it's doing that to achieve the
requested sort order), then computation of a 650-way boolean OR expression
for each row of the table.  Ugh.

The other way of doing this would involve 650 separate index probes and
then sorting the result.  Which would be pretty expensive too, but just
counting on my fingers it seems like that ought to come out at less than
the 35000 cost units for this plan.  The planner evidently is coming up
with a different answer though.  You might try dropping testindex2
(which I suppose is an index on (f,c)) so that it has only an index on
f to play with, and see what plan it picks and what the estimated/actual
costs are.

            regards, tom lane

pgsql-performance by date:

Previous
From: Alvaro Herrera
Date:
Subject: Re: Query runs 38 seconds for small database!
Next
From: Jeffrey Tenny
Date:
Subject: Re: performance question (something to do w/ parameterized