Re: Index scan plan estimates way off.

From: Robert Haas <robertmhaas(at)gmail(dot)com>
To: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
Cc: Jonathan Hseu <vomjom(at)vomjom(dot)net>, pgsql-performance(at)postgresql(dot)org
Subject: Re: Index scan plan estimates way off.
Date: 2009-03-06 02:33:06
Message-ID: 603c8f070903051833j29eba13tb3216610aa187a5@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-performance

On Thu, Mar 5, 2009 at 1:30 PM, Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> wrote:
> Jonathan Hseu <vomjom(at)vomjom(dot)net> writes:
>>  Sort  (cost=11684028.44..11761274.94 rows=30898601 width=40)
>>    Sort Key: "time"
>>    ->  Bitmap Heap Scan on ticks  (cost=715657.57..6995196.08 rows=30898601
>> width=40)
>>          Recheck Cond: (contract_id = 1)
>>          ->  Bitmap Index Scan on contract_id_time_idx
>> (cost=0.00..707932.92 rows=30898601 width=0)
>>                Index Cond: (contract_id = 1)
>> (6 rows)
>
>> This plan doesn't complete in a reasonable amount of time.  I end up having
>> to kill the query after it's been running for over an hour.
>
> The bitmap scan should be at least as efficient as the plain indexscan,
> so I suppose the problem is that the sort is slow.  What's the datatype
> of "time"?  Can this machine actually support 256MB+ work_mem, or is that
> likely to be driving it into swapping?
>
> You might learn more from enabling trace_sort and watching the
> postmaster log entries it generates.  On the whole I think the planner
> isn't making a stupid choice here: sorting a large number of rows
> usually *is* preferable to making an indexscan over them, unless the
> table is remarkably close to being in physical order for the index.

It seems like this is only likely to be true if most of the data needs
to be read from a magnetic disk, so that many seeks are involved.
That might not be the case here, since the machine has an awful lot of
RAM.

...Robert

In response to

Browse pgsql-performance by date

  From Date Subject
Next Message Aaron Guyon 2009-03-06 15:50:22 Re: Postgres 8.3, four times slower queries?
Previous Message Jonathan Hseu 2009-03-06 01:42:19 Re: Index scan plan estimates way off.