I hope you understand the rest.
select * from ( select date_add('2003-01-01 00:00:00.000', INTERVAL n5.num*10000+n4.num*1000+n3.num*100+n2.num*10+n1.num DAY ) as date from (select 0 as num union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) n1, (select 0 as num union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) n2, (select 0 as num union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) n3, (select 0 as num union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) n4, (select 0 as num union all select 1 union all select 2 union all select 3 union all select 4 union all select 5 union all select 6 union all select 7 union all select 8 union all select 9) n5 ) a where date >'2011-01-02 00:00:00.000' and date < NOW() order by date
FROM
select n3.num*100+n2.num*10+n1.num as date
you will get a column with numbers from 0 to max (n3) * 100 + max (n2) * 10 + max (n1)
Since max n3 is 3 here, SELECT will return 399 plus 0 → 400 entries (dates on the calendar).
You can customize your dynamic calendar by restricting it, for example, to min (date), which you should now ().
Igor Kryltsov May 01 '13 at 12:18 2013-05-01 12:18
source share