自 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 创建定时任务 详解的更多相关文章

  1. MySQL 联合索引详解

    MySQL 联合索引详解   联合索引又叫复合索引.对于复合索引:Mysql从左到右的使用索引中的字段,一个查询可以只使用索引中的一部份,但只能是最左侧部分.例如索引是key index (a,b,c ...

  2. MySQL关闭过程详解和安全关闭MySQL的方法

    MySQL关闭过程详解和安全关闭MySQL的方法 www.hongkevip.com 时间: -- : 阅读: 整理: 红客VIP 分享到: 红客VIP(http://www.hongkevip.co ...

  3. 【转】Nginx+php-fpm+MySQL分离部署详解

    转:http://www.linuxidc.com/Linux/2015-07/120580.htm Nginx+php-fpm+MySQL分离部署详解 [日期:2015-07-26] 来源:Linu ...

  4. Mysql加锁过程详解(8)-理解innodb的锁(record,gap,Next-Key lock)

    Mysql加锁过程详解(1)-基本知识 Mysql加锁过程详解(2)-关于mysql 幻读理解 Mysql加锁过程详解(3)-关于mysql 幻读理解 Mysql加锁过程详解(4)-select fo ...

  5. MySQL数据库优化详解(收藏)

    MySQL数据库优化详解 mysql表复制 复制表结构+复制表数据mysql> create table t3 like t1;mysql> insert into t3 select * ...

  6. (转)MySQL备份原理详解

    MySQL备份原理详解 原文:http://www.cnblogs.com/cchust/p/5452557.html 备份是数据安全的最后一道防线,对于任何数据丢失的场景,备份虽然不一定能恢复百分之 ...

  7. MySQL EXPLAIN 命令详解

    MySQL EXPLAIN 命令详解 MySQL的EXPLAIN命令用于SQL语句的查询执行计划(QEP).这条命令的输出结果能够让我们了解MySQL 优化器是如何执行SQL 语句的.这条命令并没有提 ...

  8. MySQL数据库备份详解

    原文:MySQL数据库备份详解 对于任何数据库来说,备份都是非常重要的 数据库复制不能取代备份的作用 比如我们由于误操作,在主数据库上删除了一些数据,由于主从复制的时间很短,在发现时,从数据库上的数据 ...

  9. 利用Intellij+MAVEN搭建Spring+Mybatis+MySql+SpringMVC项目详解

    http://blog.csdn.net/noaman_wgs/article/details/53893948 利用Intellij+MAVEN搭建Spring+Mybatis+MySql+Spri ...

随机推荐

  1. [atAGC106E]Medals

    暴力二分答案+网络流,点数为$o(nk)$,无法通过 考虑Hall定理,即有完美匹配当且仅当$\forall S\subseteq V_{left}$,令$S'=\{x|\exists y\in V_ ...

  2. PHP绕过MD5比较的各种姿势

    1.用==进行弱类型比较时, 可以通过两个0e开头后面纯数字的md5绕过 php在进行弱类型比较时,如果为字符串为纯数字,包括浮点数.科学计数法.十六进制数等,都会转化为数字类型再进行比较,利用这点, ...

  3. 异常处理截止和UML图

    0.异常处理机制 0.1.java中异常的作用是:增强程序健壮性. 0.2.java中异常以类和对象的形式存在. 1.java的异常处理机制 1.1.异常在java中以类和对象的形式存在.那么异常的继 ...

  4. Jenkins系列-权限管理

    在实际工作中,存在多个团队都需要Jenkins来实现持续交付,但是又希望不同团队之间进行隔离,每个项目有自己的view, 只能看到自己项目的jenkins job. 但是,jenkins默认的权限管理 ...

  5. java 代理模式实现代码

    目录 1.静态代理 2.动态代理 1.静态代理 接口类AdminService.java接口 public interface AdminService { void update(); Object ...

  6. ACAM 题乱做

    之前做了不少 ACAM,不过没怎么整理起来,还是有点可惜的. 打 * 的是推荐一做的题目. I. *CF1437G Death DBMS 见 我的题解. II. *CF1202E You Are Gi ...

  7. 🚀 RabbitMQ课程发布-KuangStudy

    RabbitMQ课程上线(44集) 视频教程地址:https://www.kuangstudy.com/course/detail/1323452886432944129 专栏地址:https://w ...

  8. flink03-----1.Task的划分 2.共享资源槽 3.flink的容错

    1. Task的划分 在flink中,划分task的依据是发生shuffle(也叫redistrubute),或者是并行度发生变化 1.  wordcount为例 package cn._51doit ...

  9. 【leetocde】922. Sort Array By Parity II

    Given an array of integers nums, half of the integers in nums are odd, and the other half are even.  ...

  10. Android获取通知栏的高度

    1 public static int getStatusBarHeight(Context context){ 2         Class<?> c = null; 3        ...