MySQL Automatic Date Dimension Build

In every system a Date Dimension is needed for multiple reasons and addresses multiple use business use cases.

What is Date Dimension?

Date Dimension is a table that has one record per each day, no more, no less! Depends on the period used in the business you can define start and end of the date dimension. In this post i will post the code i use to generate a data dimension from scratch in MySQL. Table creation 
DROP TABLE IF EXISTS time_dimension;
CREATE TABLE time_dimension (
        id                      INTEGER PRIMARY KEY,  -- year*10000+month*100+day

        db_date                 DATE NOT NULL,
        year                    INTEGER NOT NULL,
        month                   INTEGER NOT NULL, -- 1 to 12

        day                     INTEGER NOT NULL, -- 1 to 31

        quarter                 INTEGER NOT NULL, -- 1 to 4

        week                    INTEGER NOT NULL, -- 1 to 52/53

        day_name                VARCHAR(9) NOT NULL, -- 'Monday', 'Tuesday'...

        month_name              VARCHAR(9) NOT NULL, -- 'January', 'February'...

        holiday_flag            CHAR(1) DEFAULT 'f',
        weekend_flag            CHAR(1) DEFAULT 'f',
        event                   VARCHAR(50),
        UNIQUE td_ymd_idx (year,month,day),
        UNIQUE td_dbdate_idx (db_date)

) Engine=MyISAM;
Procedure to generate the Date Dimension data
DROP PROCEDURE IF EXISTS fill_date_dimension;
DELIMITER //
CREATE PROCEDURE fill_date_dimension(IN startdate DATE,IN stopdate DATE)
BEGIN
    DECLARE currentdate DATE;
    SET currentdate = startdate;
    WHILE currentdate < stopdate DO
        INSERT INTO time_dimension VALUES (
                        YEAR(currentdate)*10000+MONTH(currentdate)*100 + DAY(currentdate),
                        currentdate,
                        YEAR(currentdate),
                        MONTH(currentdate),
                        DAY(currentdate),
                        QUARTER(currentdate),
                        WEEKOFYEAR(currentdate),
                        DATE_FORMAT(currentdate,'%W'),
                        DATE_FORMAT(currentdate,'%M'),
                        'f',
                        CASE DAYOFWEEK(currentdate) WHEN 1 THEN 't' WHEN 7 then 't' ELSE 'f' END,
                        NULL);
        SET currentdate = ADDDATE(currentdate,INTERVAL 1 DAY);
    END WHILE;
END
//
DELIMITER ;
Execute Procedure
CALL fill_date_dimension('start date ','end date ');
OPTIMIZE TABLE time_dimension;
I hope this help !