Możesz użyć podzapytania, aby pogrupować dane według dnia/godziny, a następnie wziąć średnią godzinową w podzapytaniu.
Oto przykład, który pokazuje średnią liczbę godzin w ciągu ostatnich 7 dni:
select the_hour,avg(the_count)
from
(
select date(from_unixtime(`date`)) as the_day,
hour(from_unixtime(`date`)) as the_hour,
count(*) as the_count
from fb_posts
where `date` >= unix_timestamp(current_date() - interval 7 day)
and created_on < unix_timestamp(current_date())
group by the_day,the_hour
) s
group by the_hour