On Tuesday, March 17, 2015, Israel Brewster <isr...@ravnalaska.net> wrote:

>
>
> > On Mar 17, 2015, at 8:09 AM, Paul Jungwirth <p...@illuminatedcomputing.com
> <javascript:;>> wrote:
> >
> >>> test=> select h, count(*) from start_end, generate_series(0, 23) as
> s(h) where h between extract(hour from start_time) and extract(hour from
> end_time) group by h order by h;
> >>>
> >>> h  | count
> >>> ----+-------
> >>>  8 |     2
> >>>  9 |     3
> >>> 10 |     2
> >>> 11 |     2
> >
> > Note if you always want all 24 rows with a count of 0 when appropriate
> (which seems common in reports with tables or plots), you can just tweak
> the above query to use a left join: FROM generate_series(0, 23) AS s(h)
> LEFT OUTER JOIN start_end ON h BETWEEN ...
> >
> > Paul
>
> Right, thanks. That makes sense. So next question: how do I get the
> "active" time per hour from this? To use the same example that came up with
> this result set:
>


Which is why you do not (only?) want to convert your data to hour-of-day
but want to create timestamp end points.  Then you simply do timestamp
subtraction to get durations which you can then sum together.

David J.

Reply via email to