| 
                
Please start any new threads on our new 
    site at https://forums.sqlteam.com.  We've got lots of great SQL Server
    experts to answer whatever question you can come up with. 
    
        | 
                
                    | 
                            
                                | Author | Topic |  
                                    | offspring22Starting Member
 
 
                                        38 Posts | 
                                            
                                            |  Posted - 2012-07-05 : 18:24:40 
 |  
                                            | Good day everyone,I have a situation arise that I haven't come across before...I need to create some statistics for clients who have taken courses with us.  I have a table that has a record for each course a customer has taken.  For example, the registration table looks as follows:Course | CustNo | Dateclass1 | 1234 | 12/3/2005class1 | 3456 | 2/5/2007class2 | 7890 | 4/27/2009class3 | 1234 | 11/8/2006class4 | 3456 | 1/9/2011class5 | 7890 | 7/27/2005class4 | 1234 | 11/3/2010class9 | 3456 | 12/5/2010class4 | 7890 | 8/26/2008I need to find the longest time each CustNo went without taking a course.  Ie, for CustNo 1234 the longest time they went was 11/8/2006 - 11/3/2010, or about 4 years....  There can be 50 courses for 1 particular CustNO.Any idea on where to start with this?Thanks in advance! |  |  
                                    | sunitabeckMaster Smack Fu Yak Hacker
 
 
                                    5155 Posts | 
                                        
                                          |  Posted - 2012-07-05 : 21:59:00 
 |  
                                          | Here is one approach: SELECT	a.CustNo,	MAX(DATEDIFF(dd,a.Date,COALESCE(b.Date,GETDATE()))) AS MaxDaysFROM	YourTable a	OUTER APPLY	(		SELECT TOP (1) b.Date		FROM YourTable b		WHERE b.CustNo = a.CustNo		AND b.Date > a.Date		ORDER BY b.Date	)bGROUP BY	a.CustNo; |  
                                          |  |  |  
                                    | visakh16Very Important crosS Applying yaK Herder
 
 
                                    52326 Posts | 
                                        
                                          |  Posted - 2012-07-05 : 23:05:09 
 |  
                                          | [code];With CTEAS(SELECT ROW_NUMBER() OVER (PARTITION BY CustNo ORDER BY Date) AS Rn,*FROM Table)SELECT CustNo,DurationFROM(SELECT c1.CustNo,ROW_NUMBER() OVER (PARTITION BY CustNo ORDER BY DATEDIFF(dd,c1.Date,c2.Date) DESC) AS Seq, DATEDIFF(dd,c1.Date,c2.Date) AS DurationFROM CTE c1INNER JOIN CTE c2ON c2.CustNo = c1.CustNoAND c2.Rn = c1.Rn -1)tWHERE Seq=1[/code]------------------------------------------------------------------------------------------------------SQL Server MVPhttp://visakhm.blogspot.com/ |  
                                          |  |  |  
                                    | sunitabeckMaster Smack Fu Yak Hacker
 
 
                                    5155 Posts | 
                                        
                                          |  Posted - 2012-07-06 : 07:34:51 
 |  
                                          | Visakh, are you trying to confuse me? I switched from CTE's to OUTER APPLY (after much kicking and screaming, I might add) after learning the OUTER APPLY from a "Very Important crosS Applying yaK Herder". Are you now going back on me and reverting to CTE's?   |  
                                          |  |  |  
                                    | visakh16Very Important crosS Applying yaK Herder
 
 
                                    52326 Posts | 
                                        
                                          |  Posted - 2012-07-06 : 09:37:16 
 |  
                                          | quote:I just played myself as Sunita hereOriginally posted by sunitabeck
 Visakh, are you trying to confuse me? I switched from CTE's to OUTER APPLY (after much kicking and screaming, I might add) after learning the OUTER APPLY from a "Very Important crosS Applying yaK Herder". Are you now going back on me and reverting to CTE's?
  
  ------------------------------------------------------------------------------------------------------SQL Server MVPhttp://visakhm.blogspot.com/ |  
                                          |  |  |  
                                |  |  |  |  |  |