| From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> | 
|---|---|
| To: | josh(at)agliodbs(dot)com | 
| Cc: | "scott(dot)marlowe" <scott(dot)marlowe(at)ihs(dot)com>, Chris Gamache <cgg007(at)yahoo(dot)com>, pgsql-sql <pgsql-sql(at)postgresql(dot)org> | 
| Subject: | Re: Query planner: current_* vs. explicit date | 
| Date: | 2003-10-22 22:45:20 | 
| Message-ID: | 24641.1066862720@sss.pgh.pa.us | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-sql | 
Josh Berkus <josh(at)agliodbs(dot)com> writes:
>> I'd guess that the planner doesn't know what current_date::timestamp is 
>> ahead of time, so it chooses a seq scan.
> Yes, this is a known problem.  There was a single-query workaround, but I 
> can't remember it right now.
Right; the problem from the planner's point of view is that it sees
WHERE datecol >= unknownvalue
and it has no idea how much of the table will be fetched by this query.
Its default guess is that a fair fraction of the table will be fetched
(one-third, I think) and that dissuades it from using an indexscan.
This seems reasonable to me, since the worst-case behavior if it were
to default to an indexscan could be awful.
The easiest workaround is to convert the query into a range query,
for example
WHERE datecol >= current_date AND datecol <= current_date + 1000;
being careful that both comparison values are nonconstant (don't use
'infinity'::timestamp, for instance, even though that might seem like
a reasonable thing to do).  The planner still has no idea how many rows
will be fetched exactly, but it does realize that this is a range
condition, and its default assumption about the number of matching rows
is small enough to encourage indexscan use.
Of course this workaround assumes that you can pick an upper bound that
you are sure is past the end of the available values, but that's usually
not hard in the sort of context where you would have thought that the
one-sided inequality test is a sane thing to do anyway.
regards, tom lane
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Michael Glaesmann | 2003-10-23 00:32:53 | Re: Functional index problems. (Was: Many joins: monthly summaries S-L--O--W) | 
| Previous Message | Peter Eisentraut | 2003-10-22 22:01:57 | Re: Expressional Indexes |