Mysql 存储过程+事件 定时备份表
来源:互联网 发布:js行内块元素有哪些 编辑:程序博客网 时间:2024/06/08 11:43
一、背景
将界面操作日志存储在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`()BEGINcreate table operationlog_temp like operationlog;set @i=current_date();--执行rename table operationlog to operationlog_yyyy-mm-ddset @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-ddPREPARE 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_testON 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 EXISTSDROP EVENT IF EXISTS e_test;
0 0
- Mysql 存储过程+事件 定时备份表
- mysql定时执行某一存储过程,并实现mysql数据库的定时备份
- Mysql 定时任务 事件处理存储过程详解
- mysql创建存储过程和事件(定时任务)
- mysql使用存储过程和事件实现定时任务
- 定时备份数据库的存储过程.sql
- MySQL定时执行存储过程
- MYSQL定时执行存储过程
- mysql 存储过程+定时任务
- mysql-定时调用存储过程
- mysql 定时执行存储过程
- mysql存储过程 定时任务
- mysql存储过程 定时任务
- MYSQL 定时执行存储过程
- mysql 定时执行存储过程
- Mysql定时任务&存储过程
- 存储过程、定时事件的简单使用
- 存储过程、定时事件的使用
- VS上运行CUDA,并在NVDIA显卡安装的CUDA中运行OpenCL
- 在swift中cocoapods可以导入哪些第三方库
- 5s真机调试时上下出现黑边
- 视频直播技术详解之推流和传输
- c++函数模板
- Mysql 存储过程+事件 定时备份表
- 设置 PyCharm 软件中 Terminal 窗口 中启动的 python 交互命令的版本
- Tomcat启动报错,不能正常解析配置文件 Could not load META-INF/services/javax.xml.parsers.SAXParserFactory XML文件解析失败
- 关于redis的主从、哨兵、集群
- HDU4405 Aeroplane chess (概率DP求期望)
- PHP 写入文件、读取文件、获取远程文件
- Junit+spring创建JNDI运行测试用例
- powerdesigner使用说明
- Linux-Vim编辑器之快速入门(1)