I have reports that need to do this, and I know how to do it based on a datetime as long as there is data for the hour in question:
So report grouping is based on the hour of the date time then grouped each hour [8.9.10.11.12.1.2,3,4,5,6,7,8] works great.
Where i start to have issues is if...