data:image/s3,"s3://crabby-images/835f0/835f0183d68360e38201c0eea348393d05ddc0cf" alt="" |
data:image/s3,"s3://crabby-images/fedd4/fedd46b5eddfc5d215c8fcb543c21c47cbcce0b1" alt="" |
Archives of the TeradataForum
Message Posted: Wed, 20 Jan 2010 @ 10:43:50 GMT
Subj: | | Re: Workaround to avoid product join |
|
From: | | Dmitriy.Boyko |
Hi!
Try this:
SELECT
A.ID_PROD,
R.ID_MINUTE,
SUM(CASE WHEN R.ID_MINUTE = A.MINUTE_STARTING THEN A.SEC_FIRST_MIN WHEN R.ID_MINUTE =
A.MINUTE_ENDING THEN A.SEC_LAST_MIN ELSE 60 END) NB_SECONDS_SLICE FROM A A, Ref_table R
WHERE R.ID_MINUTE BETWEEN A.MINUTE_STARTING AND A.MINUTE_ENDING
AND r.id_minute * 0 = a.minute_starting * 0 -- Added by me GROUP BY A.ID_PROD, R.ID_MINUTE
There is merge join, but I don't know whether performance is good. Please, try it and report the result.
Best regards,
Dmitriy Boyko
| |