您的位置:首页 > 数据库 > MySQL

Mysql 存储过程+事件 定时备份表

2016-09-09 15:53 274 查看

一、背景

  将界面操作日志存储在MySQL数据库中的operationlog表中,如果该表不能自动备份,表中的数据会越来越多,影响速度。可以定期将表中数据备份到另外一个表中来解决。

二、解决方案

使用MySQL中的存储过程+事件解决。

存储过程逻辑为:

  1)创建一个新表operationlog_temp,各字段同operationlog相同;

  2)将表operationlog更名为operationlog_yyyy-mm-dd;

  3)将表operationlog_temp更名为operationlog

事件逻辑为:

  1)每个3个月定时调用一次存储过程bakOpLog

注意:开始事件功能(MySQL必须先开启事件功能,才能使用事件)。

查看当前是否已开启事件计划(调度器)有3种方法:

1) SHOW VARIABLES LIKE ‘event_scheduler’;

2) SELECT @@event_scheduler;

3) SHOW PROCESSLIST;

开启事件计划(调度器)开关有4种方法:重启就会销毁

1) SET GLOBAL event_scheduler = 1;

2) SET @@global.event_scheduler = 1;

3) SET GLOBAL event_scheduler = ON;

4) SET @@global.event_scheduler = ON;

1、定义存储过程bakOpLog:

CREATE DEFINER=`sa`@`%` PROCEDURE `bakOpLog`()
BEGIN
create table operationlog_temp like operationlog;
set @i=current_date();
--执行rename table operationlog to operationlog_yyyy-mm-dd
set @sqlstr=CONCAT('rename table operationlog to `operationlog_',cast(@i as char),'`');
select @sqlstr;
PREPARE renameOpLog FROM @sqlstr;
EXECUTE renameOpLog;
rename table operationlog_temp to operationlog;
END;


2、定义事件callProcedureBakOpLog

CREATE DEFINER=`sa`@`%` EVENT `callProcedureBakOpLog` ON SCHEDULE EVERY 1 DAY STARTS '2014-12-30 00:00:00' ENDS '2015-01-06 00:00:00' ON COMPLETION PRESERVE ENABLE DO call bakOpLog();


3、存储过程用到的一些语法

set @i=current_date();  //将全局变量i赋值为当前日期
set @sqlstr=CONCAT('rename table operationlog to `operationlog_',cast(@i as char),'`'); //sqlstr=rename table operationlog to operationlog_yyyy-mm-dd
PREPARE renameOpLog FROM @sqlstr;   //定义预处理语句
EXECUTE renameOpLog;    //执行预处理语句

查看创建的事件
SHOW EVENTS;
也可以在mysql库中产看event表

1) 临时关闭事件
ALTER EVENT e_test DISABLE;
2) 开启事件
ALTER EVENT e_test ENABLE;
3) 将每天清空test表改为5天清空一次:
ALTER EVENT e_test
ON SCHEDULE EVERY 5 DAY;
4) 删除事件(DROP EVENT)
DROP EVENT [IF EXISTS] event_name
例如删除前面创建的e_test事件
DROP EVENT e_test;
当然前提是这个事件存在,否则会产生ERROR 1513 (HY000): Unknown event错误,因此最好加上IF EXISTS
DROP EVENT IF EXISTS e_test;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息