From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
---|---|
To: | Jeff Janes <jeff(dot)janes(at)gmail(dot)com> |
Cc: | Thomas Mayer <thomas(dot)mayer(at)student(dot)kit(dot)edu>, pgsql-performance <pgsql-performance(at)postgresql(dot)org> |
Subject: | Re: window function induces full table scan |
Date: | 2014-01-02 22:43:12 |
Message-ID: | 18380.1388702592@sss.pgh.pa.us |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-performance |
Jeff Janes <jeff(dot)janes(at)gmail(dot)com> writes:
> On Thu, Jan 2, 2014 at 1:52 PM, Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> wrote:
>> It's possible that in the specific case you exhibit here, pushing down
>> the clause wouldn't result in changes in the window function's output for
>> the selected rows, but the optimizer doesn't have enough knowledge about
>> window functions to determine that.
> A restriction in the WHERE clause which corresponds to the PARTITION BY
> should be pushable, no? I think it doesn't need to understand the internal
> semantics of the window function itself, just of the PARTITION BY, which
> should be doable, at least in principle.
If the restriction clause must give the same answer for any two rows of
the same partition, then yeah, we could in principle push it down without
knowing anything about the specific window function. It'd be a less than
trivial test to make, I think. In any case, it's not a "bug" that the
optimizer doesn't do this currently.
regards, tom lane
From | Date | Subject | |
---|---|---|---|
Next Message | Thomas Mayer | 2014-01-02 22:45:56 | Re: window function induces full table scan |
Previous Message | Jeff Janes | 2014-01-02 22:26:31 | Re: window function induces full table scan |