I have an app that needs to show a bar graph for activity over the last 30 days. The graph needs to show all days even if there is no activity for the day.
for example:
DATE       COUNT ================== 1/1/2011   5  1/2/2011   3  1/3/2011   0 1/4/2011   4 1/5/2011   0 etc.... I could do post processing after the query to figure out what dates are missing and add them but was wondering if there is an easier way to do it in SQL Server. Thanks much
SELECT * FROM PERSONAL WHERE BIRTH_DATE_TIME BETWEEN '2001-03-01 11:00:00' AND '2005-03-01 22:00:00';
If you want to get a day from a date in a table, use the SQL Server DAY() function. This function takes only one argument – the date. This can be a date or date and time data type. (In our example, the column VisitDate is of the date data type.)
You can use a recursive CTE to build your list of 30 days, then join that to your data
--test select cast('05 jan 2011' as datetime) as DT, 1 as val into #t union all select CAST('05 jan 2011' as datetime), 1  union all select CAST('29 jan 2011' as datetime), 1   declare @start datetime = '01 jan 2011' declare @end   datetime = dateadd(day, 29, @start)  ;with amonth(day) as (     select @start as day         union all     select day + 1         from amonth         where day < @end ) select amonth.day, count(val)     from amonth      left join #t on #t.DT = amonth.day group by amonth.day   >>  2011-01-04 00:00:00.000 0 2011-01-05 00:00:00.000 2 2011-01-06 00:00:00.000 0 2011-01-07 00:00:00.000 0 2011-01-08 00:00:00.000 0 2011-01-09 00:00:00.000 0 ... Using CTE:
WITH DateTable AS (     SELECT CAST('20110101' AS Date) AS [DATE]     UNION ALL     SELECT DATEADD(dd, 1, [DATE])     FROM DateTable     WHERE DATEADD(dd, 1, [DATE]) < cast('20110201' as Date) ) SELECT dt.[DATE], ISNULL(md.[COUNT], 0) as [COUNT] FROM [DateTable] dt LEFT JOIN [MyData] md ON md.[DATE] = dt.[DATE] This is assuming everything's a Date; if it's DateTime, you'll have to truncate (with DATEADD(dd, 0, DATEDIFF(dd, 0, [DATE]))).
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With