mysql - 定时计划分表,预创建第二天的表

1 创建存储过程:copy 存在的空表,预创建第二天的表,并删除 7 天前的表

CREATE PROCEDURE create_monitor_log_table_every_day()
BEGIN
-- 预先创建第二天的表
SET @nowDateStr = DATE_FORMAT(date_add(curdate(),interval 1 DAY),"%Y%m%d");
SET @createStr = CONCAT("create table if not EXISTS monitor_log_" ,@nowDateStr," like monitor_log");
PREPARE stmt FROM @createStr;
EXECUTE stmt;

-- 删除7天前的存储
SET @nowDateStr = DATE_FORMAT(SUBDATE(curdate(),interval 7 DAY),"%Y%m%d");
SET @createStr = CONCAT("drop table if EXISTS monitor_log_" ,@nowDateStr);
PREPARE stmt FROM @createStr;
EXECUTE stmt;
END;

1.2 如果报错:[Err] 1055 - Expression #1 of ORDER BY clause is not in GROUP BY clause and contains nonaggregated column 'information_schema.PROFILING.SEQ' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_gr...

修改 MySQL mysql.ini 配置文件,在 [mysqld] 下面添加:

sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION

重启 mysql,重新执行即可。

2 创建 MySQL 任务计划,每天执行



-- 创建定时任务
-- 以$$作为分隔符
DELIMITER $$
SET GLOBAL event_scheduler = 1;  
-- 事件名
CREATE EVENT event_build_table_every_day
-- 间隔一天
ON SCHEDULE EVERY 1 DAY
-- 第一次执行时间
STARTS NOW() 
ON  COMPLETION  PRESERVE  
ENABLE  
DO  
BEGIN  
-- 要调用的函数或者存储过程
CALL create_monitor_log_table_every_day();  
-- CALL create_monitor_table_every_day();  
END $$  
-- 将分隔符重置为;
DELIMITER ;

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值