Joe Yoder wrote on 2014-06-08: 
>  Scenario:
>     - Cursor with 2 fields  TimeStamp T, and Value N(4.0) - 1 record per
>     second - Output needed - BegStamp as the beginning of a time period
>     X seconds long and Avg as the average of the Value field for X
>     seconds
>  With X = 3600 the results should give the average value for each hour.
>  
>  I'm stuck on what to use for a group by expression and suspect that the
>  best way may be to hard code a pair of loops that increments through the
>  cursor one time period at a time.
>  
>  Does anyone want to show me a better way?
>  
>  Thanks in advance,
>  
>  Joe
> 

Joe,

I would accomplish this using a subquery.

   CREATE CURSOR joe (TimeStamp T, Value n(4))
   FOR nn = 1 TO 10000
   INSERT INTO joe VALUES (DATETIME() + nn, 1000*RAND())
   NEXT

   startTime = DATETIME() + 1234
   endTime = startTime + 3600 - 1 && fencepost

   SELECT grouping, AVG(value) ;
      FROM (SELECT value, 1 as grouping ;
         FROM joe ;
         WHERE TimeStamp between startTime AND endTime) ;
      average GROUP BY 1


Tracy Pearson
PowerChurch Software


_______________________________________________
Post Messages to: [email protected]
Subscription Maintenance: http://mail.leafe.com/mailman/listinfo/profox
OT-free version of this list: http://mail.leafe.com/mailman/listinfo/profoxtech
Searchable Archive: http://leafe.com/archives/search/profox
This message: 
http://leafe.com/archives/byMID/profox/[email protected]
** All postings, unless explicitly stated otherwise, are the opinions of the 
author, and do not constitute legal or medical advice. This statement is added 
to the messages for those lawyers who are too stupid to see the obvious.

Reply via email to