replace selfjoin with analytic functions

Posted by edwards on Stack Overflow See other posts from Stack Overflow or by edwards
Published on 2010-03-19T10:26:02Z Indexed on 2010/03/19 10:31 UTC
Read the original article Hit count: 361

Filed under:
|
|

Hi

Any ideas how i go about replacing the following self join using analytics

SELECT 
t1.col1 col1,
t1.col2 col2,
SUM((extract(hour FROM (t1.times_stamp - t2.times_stamp)) * 3600 + extract(minute FROM ( t1.times_stamp - t2.times_stamp)) * 60 + extract(second FROM ( t1.times_stamp - t2.times_stamp)) ) ) div,
COUNT(*) tot_count
FROM tab1 t1,
tab1 t2
WHERE t2.col1      = t1.col1
AND t2.col2  = t1.col2
AND t2.col3        = t1.sequence_num
AND t2.times_stamp     < t1.times_stamp
AND t2.col4         = 3
AND t1.col4         = 4
AND t2.col5 NOT IN(103,123)
AND t1.col5     != 549
GROUP BY t1.col1, t1.col2

© Stack Overflow or respective owner

Related posts about Oracle

Related posts about analytic