I'm sure this has been answered before, but I can't find it in the detail that I need.
For an analytics system I need to be able to group rows and return them on a chart, either grouped by minute, hour, day, month, or year. I have this working correctly (example code below).
SELECT COUNT( DISTINCT user_id ) , `hour` , `timestamp`
FROM tracking_request
WHERE site_id = '3'
AND `timestamp` < '2011-08-31 04:05:45'
AND `timestamp` > '2011-08-29 22:00:00'
GROUP BY `hour` , `day` , `month` , `year`
ORDER BY `timestamp` ASC
The problem is, like most charts, I need to fill the gaps where the data isn't (eg. no rows for the last 3 minutes). I read about creating a "calendar table" and joining that data, but how can I do this efficiently for each scale (eg. year would be a lot easier then minute, as minute would require MANY rows in the table)? If it helps, there is a column for each in the table (like above, you can see there is "hour", "day", etc.)
EDIT:
I ended up using PHP to accoplish this by using an empty array and then filling it. If anyone could think of an all (or mostly) SQL solution for this that would be more awesome.
See Question&Answers more detail:os