MySQL 创建定时任务 详解
自 MySQL5.1.6起,增加了一个非常有特色的功能–事件调度器(Event Scheduler),可以用做定时执行某些特定任务,来取代原先只能由操作系统的计划任务来执行的工作。事件调度器有时也可称为临时触发器(temporal triggers),因为事件调度器是基于特定时间周期触发来执行某些任务,而触发器(Triggers)是基于某个表所产生的事件触发的,区别也就在这里
在使用这个功能之前必须确保 event_scheduler 已开启,可执行 :
mysq> SET GLOBAL event_scheduler = 1;
# 或
mysql> SET GLOBAL event_scheduler = ON;
也可以在配置文件中添加设置 : event_scheduler=1
也可以直接在启动命令加上 : --event_scheduler=1
查看当前是否已开启事件调度器 :
mysql> SHOW VARIABLES LIKE 'event_scheduler';
+-----------------+-------+
| Variable_name | Value |
+-----------------+-------+
| event_scheduler | ON |
+-----------------+-------+
1 row in set (0.01 sec)
# 或
mysql> SELECT @@event_scheduler;
+-------------------+
| @@event_scheduler |
+-------------------+
| ON |
+-------------------+
1 row in set (0.00 sec)
# 或
mysql> SHOW PROCESSLIST;
+----+-----------------+-----------+------+---------+------+------------------------+------------------+
| Id | User | Host | db | Command | Time | State | Info |
+----+-----------------+-----------+------+---------+------+------------------------+------------------+
| 6 | root | localhost | NULL | Query | 0 | starting | SHOW PROCESSLIST |
| 7 | event_scheduler | localhost | NULL | Daemon | 81 | Waiting on empty queue | NULL |
+----+-----------------+-----------+------+---------+------+------------------------+------------------+
2 rows in set (0.00 sec)
创建事件(CREATE EVENT)
CREATE EVENT [IFNOT EXISTS] event_name
ON SCHEDULE schedule
[ON COMPLETION [NOT] PRESERVE]
[ENABLE | DISABLE]
[COMMENT 'comment']
DO sql_statement;
[ON COMPLETION [NOT] PRESERVE] 可以设置这个事件是执行一次还是持久执行,默认为 NOT PRESERVE
[ENABLE | DISABLE] 可是设置该事件创建后状态是否开启或关闭,默认为ENABLE
[COMMENT 'comment'] 可以给该事件加上注释
# 创建表
mysql> USE Test;
mysql> CREATE TABLE aaa(timeline TIMESTAMP);
# 每秒插入一条记录到数据表
mysql> CREATE EVENT e_test_insert ON SCHEDULE EVERY 1 SECOND
-> DO INSERT INTO test.aaa VALUES(CURRENT_TIMESTAMP);
mysql> SELECT * FROM aaa;
# 5天后清空 test表
mysql> CREATE EVENT e_test
-> ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 5 DAY
-> DO TRUNCATE TABLE test.aaa;
# 2018年8月8日8点整清空 test表
mysql> CREATE EVENT e_test
-> ON SCHEDULE AT TIMESTAMP '2018-08-08 8:00:00'
-> DO TRUNCATE TABLE test.aaa;
# 每天定时清空 test表
mysql> CREATE EVENT e_test
-> ON SCHEDULE EVERY 1 DAY
-> DO TRUNCATE TABLE test.aaa;
# 5天后开启每天定时清空test表
mysql> CREATE EVENT e_test
-> ON SCHEDULE EVERY 1 DAY
-> STARTS CURRENT_TIMESTAMP + INTERVAL 5 DAY
-> DO TRUNCATE TABLE test.aaa;
# 每天定时清空 test表,5天后停止执行
mysql> CREATE EVENT e_test
-> ON SCHEDULE EVERY 1 DAY
-> ENDS CURRENT_TIMESTAMP + INTERVAL 5 DAY
-> DO TRUNCATE TABLE test.aaa;
# 5天后开启每天定时清空test表,一个月后停止执行
mysql> CREATE EVENT e_test
-> ON SCHEDULE EVERY 1 DAY
-> STARTS CURRENT_TIMESTAMP + INTERVAL 5 DAY
-> ENDS CURRENT_TIMESTAMP + INTERVAL 1 MONTH
-> DO TRUNCATE TABLE test.aaa;
# 每天定时清空test表(只执行一次,任务完成后就终止该事件)
mysql> CREATE EVENT e_test
-> ON SCHEDULE EVERY 1 DAY
-> ON COMPLETION NOT PRESERVE
-> DO TRUNCA TETABLE test.aaa;
修改事件(ALTER EVENT)
ALTER EVENT event_name
[ON SCHEDULE schedule]
[RENAME TO new_event_name]
[ON COMPLETION [NOT] PRESERVE]
[COMMENT 'comment']
[ENABLE | DISABLE]
[DO sql_statement]
# 临时关闭事件
mysql> ALTER EVENT e_test DISABLE;
# 开启事件
mysql> ALTER EVENT e_test ENABLE;
# 将每天清空test表改为5天清空一次
mysql> ALTER EVENT e_test ON SCHEDULE EVERY 5 DAY;
注 : 如果将 event 执行 ALTER EVENT event_name DISABLE. 那么当重新启动 mysql服务器后,该 event 将被删除
删除事件(DROP EVENT)
DROP EVENT [IF EXISTS] event_name
# 删除创建的 e_test事件
mysql> DROP EVENT e_test; # 如果该事件不存在将会产生 ERROR 1513 (HY000): Unknown event 错误,因此最好加上IF EXISTS
mysql> DROP EVENT IF EXISTS e_test;
每秒钟调用一次存储过程,用于判断 SLAVE 是否正常运行,如果发现 SLAVE 关闭了,忽略 0 次错误,然后重新启动 SLAVE
mysql> DELIMITER //
-> CREATE PROCEDURE Slave_Monitor()
-> BEGIN
-> SELECT VARIABLE_VALUE INTO @SLAVE_STATUS FROM information_schema.GLOBAL_STATUS WHEREVARIABLE_NAME='SLAVE_RUNNING';
-> IF ('ON'!= @SLAVE_STATUS) THEN
-> SET GLOBAL SQL_SLAVE_SKIP_COUNTER=0;
-> SLAVE START;
-> ENDIF;
-> END; //
-> DELIMITER;
# 由于存储过程中无法调用类似 SHOW SLAVE STATUS 这样的语句,因此无法得到确切的复制错误信息和错误代码,不能进一步的处理 SLAVE 停止的各种情况
mysql> CREATE EVENT IF NOT EXISTS Slave_Monitor
-> ON SCHEDULE EVERY 5 SECOND
-> ON COMPLETION PRESERVE
-> DO CALL Slave_Monitor();
————————————————
版权声明:本文为CSDN博主「小柴的生活观」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/chenshun123/article/details/79677193
MySQL 创建定时任务 详解的更多相关文章
- MySQL 联合索引详解
MySQL 联合索引详解 联合索引又叫复合索引.对于复合索引:Mysql从左到右的使用索引中的字段,一个查询可以只使用索引中的一部份,但只能是最左侧部分.例如索引是key index (a,b,c ...
- MySQL关闭过程详解和安全关闭MySQL的方法
MySQL关闭过程详解和安全关闭MySQL的方法 www.hongkevip.com 时间: -- : 阅读: 整理: 红客VIP 分享到: 红客VIP(http://www.hongkevip.co ...
- 【转】Nginx+php-fpm+MySQL分离部署详解
转:http://www.linuxidc.com/Linux/2015-07/120580.htm Nginx+php-fpm+MySQL分离部署详解 [日期:2015-07-26] 来源:Linu ...
- Mysql加锁过程详解(8)-理解innodb的锁(record,gap,Next-Key lock)
Mysql加锁过程详解(1)-基本知识 Mysql加锁过程详解(2)-关于mysql 幻读理解 Mysql加锁过程详解(3)-关于mysql 幻读理解 Mysql加锁过程详解(4)-select fo ...
- MySQL数据库优化详解(收藏)
MySQL数据库优化详解 mysql表复制 复制表结构+复制表数据mysql> create table t3 like t1;mysql> insert into t3 select * ...
- (转)MySQL备份原理详解
MySQL备份原理详解 原文:http://www.cnblogs.com/cchust/p/5452557.html 备份是数据安全的最后一道防线,对于任何数据丢失的场景,备份虽然不一定能恢复百分之 ...
- MySQL EXPLAIN 命令详解
MySQL EXPLAIN 命令详解 MySQL的EXPLAIN命令用于SQL语句的查询执行计划(QEP).这条命令的输出结果能够让我们了解MySQL 优化器是如何执行SQL 语句的.这条命令并没有提 ...
- MySQL数据库备份详解
原文:MySQL数据库备份详解 对于任何数据库来说,备份都是非常重要的 数据库复制不能取代备份的作用 比如我们由于误操作,在主数据库上删除了一些数据,由于主从复制的时间很短,在发现时,从数据库上的数据 ...
- 利用Intellij+MAVEN搭建Spring+Mybatis+MySql+SpringMVC项目详解
http://blog.csdn.net/noaman_wgs/article/details/53893948 利用Intellij+MAVEN搭建Spring+Mybatis+MySql+Spri ...
随机推荐
- [luogu4259]寻找车位
考虑一个分治的做法:按行分治,将所有区间分为两类--经过分割线的.在左/右区间内部,后者显然可以递归下取,考虑前者 先求出出该行上每一列向上和向下的最大长度,记作$up_{i}$和$down_{i}$ ...
- 微信小程序如何重写Page方法?以及重写Page方法给开发者带来的好处
17,18年的时候,我当时主要开发小程序,那时候领导想看一下小程序的访问量,还有一些埋点的需求,于是我们的小程序就接入了阿拉丁统计. 阿拉丁的接入方式除了配置以外,主要就一行引入代码.官方要求将以下代 ...
- python中使用正则表达式处理文本(仅记录常用方法和参数)
标准库模块 python中通过re模块使用正则表达式 import re 常用方法 生成正则表达式对象 compile(pattern[,flags]) pattern:正则表达式字符串 flags: ...
- 21天从Java转向Go之第三天——初出茅庐
名称 Go中25个关键字 只能在语法允许的地方使用,不能做为名称 break default func interface select case defer go map struct chan e ...
- java的String参数格式化
String类的format()方法用于创建格式化的字符串以及连接多个字符串对象.熟悉C语言的同学应该记得C语言的sprintf()方法,两者有类似之处.format()方法有两种重载形式. form ...
- 计算机系统->Hello World的一生 | 程序如何运行
2021年11月27日准备发在基地微信公众号上的推文. 综合了多篇大佬的博客,以及自己已经知道的知识,对一些疑惑进行了现阶段我认为还算满意的解答. 不过又产生了很多疑问: 内存和磁盘的关系 CPU是如 ...
- pycharm的selenium设置
如果运行文件,提示 no model named selenium 那就需要添加selenium的安装地址 如上图 在python>lib>site-packages 在pycharm的f ...
- 【2020五校联考NOIP #3】序列
题面传送门 原题题号:Codeforces Gym 101821B 题意: 给出一个排列 \(p\),要你找出一个最长上升子序列(LIS)和一个最长下降子序列(LDS),满足它们没有公共元素.或告知无 ...
- Educational Codeforces Round 94 题解
我竟然比到了全场的 rk 14,incredible! A 大水题,直接输出 \(n\) 遍 \(s_n\) 即可. B 分类讨论题,放在 B 题可能难度有点大了. 直接暴力枚举你拿了多少个宝剑,然后 ...
- 【GS文献】植物全基因组选择育种技术原理与研究进展
目录 1. 优势杂交育种预测 2. GS育种原理与模型算法 岭回归和LASSO回归 贝叶斯方法 GBLUP和RRBLUP 偏最小二乘法 支持向量机/支持向量回归 其他方法 3. 模型预测能力验证 4. ...