data:image/s3,"s3://crabby-images/835f0/835f0183d68360e38201c0eea348393d05ddc0cf" alt="" |
data:image/s3,"s3://crabby-images/fedd4/fedd46b5eddfc5d215c8fcb543c21c47cbcce0b1" alt="" |
Archives of the TeradataForum
Message Posted: Thu, 02 May 2008 @ 00:04:02 GMT
Subj: | | Re: Retrieving the Second Highest Amount |
|
From: | | Dieter Noeth |
Michael Larkins wrote:
| The real question is whether or not the optimizer is acting correctly in its choice regarding the timing of applying the WHERE
conditions. | |
Of course the optimizer is right, it can only push a condition into a view/derived table, if it's not changing the result set.
Just imagine the condition pushed into a view doing an aggregation,
removing rows before the SUM.
| Otherwise, why does the optimizer not always read all rows into spool and then select from spool based on the select from the
view. | |
If you use a (PARTITION BY customer, cust_date), then it will push a condition on cust_date.
There's no efficient solution (beside Victor's proposition, which will result in a huge cross join/spool) to Megan's problem including all 4
requirements.
Dieter
| |