mysql獲取給定時間段內的所有日期列表


DELIMITER $$
DROP PROCEDURE IF EXISTS create_calendar $$
CREATE PROCEDURE create_calendar (s_date DATE, e_date DATE)
BEGIN
  -- 生成一個日歷表
    SET @createSql = 'CREATE TABLE IF NOT EXISTS calendar_custom (
                      `date` date NOT NULL,
                      UNIQUE KEY `unique_date` (`date`) USING BTREE
                      )ENGINE=InnoDB DEFAULT CHARSET=utf8';
    prepare stmt from @createSql;
    execute stmt;
    WHILE s_date <= e_date DO
        INSERT IGNORE INTO calendar_custom VALUES (DATE(s_date)) ;
        SET s_date = s_date + INTERVAL 1 DAY ;
    END WHILE ;
END$$
DELIMITER ;

-- 生成數據到calendar_custom表2009-01-01~2029-01-01之間的所有日期數據
CALL create_calendar ('2009-01-01', '2029-01-01');

  

DELIMITER $$
DROP PROCEDURE IF EXISTS create_calendar $$
CREATE PROCEDURE create_calendar (s_date DATE, e_date DATE)
BEGIN
  
  -- 生成一個日歷表
    SET @createSql = 'truncate TABLE  calendar_custom';
    prepare stmt from @createSql;
    execute stmt;
  
    WHILE s_date <= e_date DO
        INSERT IGNORE INTO calendar_custom VALUES (DATE(s_date)) ;
        SET s_date = s_date + INTERVAL 1 DAY ;
    END WHILE ;
  
END$$
DELIMITER ;
 
-- 生成數據到calendar_custom表2009-01-01~2029-01-01之間的所有日期數據
 CALL create_calendar ('2009-01-02', '2009-01-07');

  

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM