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 ...
随机推荐
- [noi713]魔法
分治,维护一个dp数组,当递归到区间[l,r]时,需要保证这个dp数组维护的是除去[l,r]以外的dp数组维护其实很简单,就是递归左区间是先将右区间加入,然后再将左区间加入(要先复原)然后递归右区间即 ...
- 【2020-8-21】【数字游戏】【启发式搜索IDA*】
有这么一个游戏: 写出一个1-N的排列a[i],然后每次将相邻两个数相加,构成新的序列,再对新序列进行这样的操作,显然每次构成的序列都比上一次的序列长度少1,直到只剩下一个数字位置.下面是一个例子: ...
- Codeforces 348C - Subset Sums(根号分治)
题面传送门 对于这类不好直接维护的数据结构,第一眼应该想到-- 根号分治! 我们考虑记[大集合]为大小 \(\geq\sqrt{n}\) 的集合,[小集合]为大小 \(<\sqrt{n}\) 的 ...
- FFT/NTT复习笔记&多项式&生成函数学习笔记Ⅲ
第三波,走起~~ FFT/NTT复习笔记&多项式&生成函数学习笔记Ⅰ FFT/NTT复习笔记&多项式&生成函数学习笔记Ⅱ 单位根反演 今天打多校时 1002 被卡科技了 ...
- Codeforces 704C - Black Widow(dp)
Codeforces 题目传送门 & 洛谷题目传送门 u1s1 感觉这种题被评到 *2900 是因为细节太繁琐了,而不是题目本身的难度,所以我切掉这种题根本不能说明什么-- 首先题目中有一个非 ...
- Codeforces 521D - Shop(贪心)
Codeforces 题目传送门 & 洛谷题目传送门 一道不算太难的贪心,可惜又没自己想出来,显然省选之后我的能力呈 \(y=-1145141919810192608179998244353x ...
- CF1437G Death DBMS
题面传送门. 题意简述:给出 \(n\) 个字符串 \(s_i\),每个 \(s_i\) 初始权值为 \(0\).\(q\) 次操作:修改 \(s_i\) 的权值:查询给出字符串 \(q\) 能匹配的 ...
- NAT 工作原理
网络地址转换,就是替换IP报文头部的地址信息.NAT通常部署在一个组织的网络出口位置,通过将内部网络IP地址替换为出口的IP地址提供公网可达性和上层协议的连接能力 规定了三个保留地址段落:10.0.0 ...
- flask分页功能:基于flask-sqlalchemy和jinja2
先看源码: @app.route('/movie', methods=['GET', 'POST']) @app.route('/home', methods=['GET', 'POST']) @ap ...
- C 语言中求中间数时候防止溢出方法
当使用二分法时候,注意 mid = left + (right - left) / 2; 这句代码,可以防止溢出!!,千万不能写成 mid = (left + right) / 2 这样写的话,当数字 ...