From: | Shaun Thomas <sthomas(at)optionshouse(dot)com> |
---|---|
To: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
Cc: | "pgsql-performance(at)postgresql(dot)org" <pgsql-performance(at)postgresql(dot)org> |
Subject: | Re: Possible Performance Regression with Transitive Comparisons vs. Constants |
Date: | 2012-09-28 21:37:40 |
Message-ID: | 506618A4.70706@optionshouse.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-performance |
On 09/28/2012 03:35 PM, Tom Lane wrote:
> 9.1.what? For me, 8.2.23 and 9.1.6 produce the same plan and just
> about the same runtime for your query 1.
I withdraw that part of my question. I apparently didn't look closely
enough at the actual output. I was basing the version assumption on the
query speed on the new server, when it was probably due to cache effects.
The first part of the question stands, though... Why isn't the optimizer
substituting these values? a.created_date should be exactly equivalent
to '2012-05-05', but it's clearly not being treated that way.
With the full substitutions, I'm seeing things like this:
http://explain.depesz.com/s/3T4
With the column names, it's this:
http://explain.depesz.com/s/Fq7
This is on 8.2, but the behavior is the same on 9.1. From 130s to 23s
simply by substituting the constant wherever the column name is
encountered. For reference, the queries are, slow:
select a.id, f.ezorder_id
from reporting.account a
join ezorder f on f.account_id = a.account_id
where a.process_date = '2012-09-27'
and f.date_created between a.process_date - interval '6 months'
and a.process_date
and a.row_out is null
And fast:
select a.id, f.ezorder_id
from reporting.account a
join ezorder f on f.account_id = a.account_id
where a.process_date = '2012-09-27'
and f.date_created between '2012-09-27'::date - interval '6 months'
and '2012-09-27'
and a.row_out is null
We discovered this during the upgrade, but it seems to equally apply to
both 8.2 and 9.1. I've been telling the devs to replace any of these
they find all day. I can't quite say why we never "noticed" this before,
but it got exposed today pretty plainly. If this were a compiler, I'd
have expected it to treat the values as equivalent, but that's clearly
not what's happening.
--
Shaun Thomas
OptionsHouse | 141 W. Jackson Blvd. | Suite 500 | Chicago IL, 60604
312-444-8534
sthomas(at)optionshouse(dot)com
______________________________________________
See http://www.peak6.com/email_disclaimer/ for terms and conditions related to this email
From | Date | Subject | |
---|---|---|---|
Next Message | Tom Lane | 2012-09-28 21:44:32 | Re: Query plan, nested EXISTS |
Previous Message | Matt Daw | 2012-09-28 21:04:04 | Query plan, nested EXISTS |