我是靠谱客的博主 优秀手链,最近开发中收集的这篇文章主要介绍mysql定时任务学习笔记,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

事件调度器(Event Scheduler)

1. 开启事件调度器

1) SET GLOBAL event_scheduler = 1;
2) 在my.cnf文件中添加event_scheduler = 1
3) SET GLOBAL event_scheduler = ON;
4) 在启动命令加上 --event_scheduler=1

2.关闭事件调度器

1SET GLOBAL event_scheduler = 0;
2SET GLOBAL event_scheduler = OFF;

3.查看当前是否已开启事件调度器

1) SHOW VARIALES LIKE 'event_scheduler';
2) SELECT @@event_scheduler;
3) SHOW PROCESSLIST;

事件任务

1.操作事件任务

1) 关闭事件任务:ALTER EVENT eventName ON COMPLETION PRESERVE DISABLE;
2) 开启事件任务:ALTER EVENT eventName ON COMPLETION PRESERVE ENABLE;
3) 查看事件任务:SHOW EVENTS;

2.创建事件

  1. 语法:
CREATE EVENT [IFNOT EXISTS] event_name
   ON SCHEDULE schedule -- 用于定义执行的时间和时间间隔
   [ONCOMPLETION [NOT] PRESERVE] -- 设置当前事件是执行一次还是持久执行,默认为一次执行(NOT PRESERVE),PRESERVE的作用是使事件在执行完毕后不会被Drop掉
   [ENABLE | DISABLE] -- 设置该事件创建后状态是否开启或关闭,默认为ENABLE
   [COMMENT 'comment'] -- 可以给该事件加上注释
   DO sql_statement;
schedule:
   AT TIMESTAMP [+ INTERVAL INTERVAL]
   | EVERY INTERVAL [STARTS TIMESTAMP] [ENDS TIMESTAMP]
  
  INTERVAL:
   quantity {YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE |
   WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE |
   DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND}
  1. 案例:
-- 1.每秒插入一条记录到数据表:
create event e_test_insert
on schedule every 1 second
do insert user values('admin','123');
-- 2.5天后清空test表:
create event e_test
on schedule at current_timestamp+interval 5 day
-- 3.2007年7月20日12点整清空test表:
create event e_test1
on schedule at timestamp '2007-07-20 12:00:00'
do truncate table test
-- 4.每天定时清空test表:
create event test2
on schedule every 1 day
do truncate test
-- 5.5天后开启每天定时清空test表:
create event e_test3
on schedule every 1 day
starts current_timestamp+interval 5 day
do truncate test
-- 6.每天定时清空test表,5天后停止执行:
create event e_test4
on schedule every 1 day
ends current_timestamp+interval 5 day
do truncate test
-- 7.5天后开启每天定时清空test表,一个月后停止
create event e_test5
on schedule every 1 day
starts current_timestamp+interval 5 day
ends current_timestamp+interval 1 month
do truncate test
-- 8.每天定时清空test表(只执行一次,任务完成后就终止该事件)
create event e_test6
on schedule every 1 day
on completion not reserve
do truncate test

3.修改事件

  1. 语法:
ALTER EVENT event_name
   [ONSCHEDULE schedule]
   [RENAME TOnew_event_name]
   [ON COMPLETION [NOT] PRESERVE]
   [COMMENT 'comment']
   [ENABLE | DISABLE]
   [DO sql_statement]
  1. 案例
-- 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.删除事件

  1. 语法:
DROP EVENT [IF EXISTS] event_name
  1. 案例:
-- 删除创建的e_test事件
drop event e_test
-- 如果不存在,产生ERROR 1513 (HY000): Unknown event错误 
-- 添加if exists
drop event if exists e_test
-- 如果将event执行了Alter event event_name disable.当重新启动mysql服务器后,该event将被删除(测试版本:5.1.30)

计划任务

ONSCHEDULE两种设定计划任务方式:

-- ON SCHEDULE 计划任务,有两种设定计划任务的方式:
1)AT 时间戳,用来完成单次的计划任务
2)EVERY 时间(单位)的数量实践单位[STARTS 时间戳] [ENDS时间戳],用来完成重复的计划任务。

在两种计划任务中,时间戳可以是任意的TIMESTAMP 和DATETIME 数据类型,时间戳需要大于当前时间。  
在重复的计划任务中,时间(单位)的数量可以是任意非空(Not Null)的整数式,时间单位是关键词:YEAR,MONTH,DAY,HOUR,MINUTE 或者SECOND。
  提示: 其他的时间单位也是合法的如:QUARTER, WEEK, YEAR_MONTH,DAY_HOUR,DAY_MINUTE,DAY_SECOND,HOUR_MINUTE,HOUR_SECOND,MINUTE_SECOND,不建议使用这些不标准的时间单位。

应用案例

利用 event scheduler 的特性,每秒钟调用一次存储过程,用于判断 SLAVE 是否正常运行,如果发现 SLAVE 关闭了,忽略 0 次错误,然后重新启动 SLAVE。

-- 1)创建存储过程
CREATE PROCEDURE Slave_Monitor()
BEGIN
SELECT VARIABLE_VALUE INTO @SLAVE_STATUS
FROM information_schema.GLOBAL_STATUS
WHERE VARIABLE_NAME='SLAVE_RUNNING';
IF('ON'!=@SLAVE_STATUS) THEN
SET GLOBAL SQL_SLAVE_SKIP_COUNTER=0;
SLAVE START;
END IF;
END;
-- 2)创建定时任务
CREATE EVENT IF NOT EXISTS Slave_Monitor
ON SCHEDULE EVERY 5 SECOND
ON COMPLETION PRESERVE
DO CALL Slave_Monitor();
-- 如果在运行中想要临时关闭一下某个任务,执行 ALTER EVENT 语句即可:
ALTER EVENT Slave_Monitor ON COMPLETION PRESERVE DISABLE;  ##关闭事件
ALTER EVENT Slave_Monitor ON COMPLETION PRESERVE ENABLE;  ##开启事件

参考资料:https://www.cnblogs.com/javahr/p/9664203.html

最后

以上就是优秀手链为你收集整理的mysql定时任务学习笔记的全部内容,希望文章能够帮你解决mysql定时任务学习笔记所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(50)

评论列表共有 0 条评论

立即
投稿
返回
顶部