码迷,mamicode.com
首页 > 数据库 > 详细

mysql获取给定时间段内的所有日期列表

时间:2020-05-22 19:01:06      阅读:482      评论:0      收藏:0      [点我收藏+]

标签:default   round   set   innodb   fan   mys   获取   ping   neu   

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‘);

  

 

mysql获取给定时间段内的所有日期列表

标签:default   round   set   innodb   fan   mys   获取   ping   neu   

原文地址:https://www.cnblogs.com/liangmm/p/12938857.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!