MySQL中的事件调度器,EVENT,也叫定时任务,类似于Unix crontab或Windows任务调度程序。

EVENT由其名称和所在的schema唯一标识。

EVENT根据计划执行特定操作。操作由SQL语句组成,语句可以是BEGIN…END语句块。EVENT可以是一次性的,也可以是重复性的。一次性EVENT只执行一次,周期性EVENT以固定的间隔重复其操作,并且可以为周期性EVENT指定开始日期和时间、结束日期和时间。(默认情况下,定期EVENT在创建后立即开始,并无限期地继续,直到它被禁用或删除。)

EVENT由一个特殊的事件调度器线程执行,用SHOW PROCESSLIST可以查看。

root@database-one 13:44: [gftest]> show variables like '%scheduler%';

+-----------------+-------+

| Variable_name | Value |

+-----------------+-------+

| event_scheduler | OFF |

+-----------------+-------+

1 row in set (0.01 sec)

root@database-one 13:46: [gftest]> show processlist;

+--------+------+----------------------+-----------+---------+------+----------+------------------+

| Id | User | Host | db | Command | Time | State | Info |

+--------+------+----------------------+-----------+---------+------+----------+------------------+

......

+--------+------+----------------------+-----------+---------+------+----------+------------------+

245 rows in set (0.00 sec)

root@database-one 13:46: [gftest]> set global event_scheduler=1;

Query OK, 0 rows affected (0.00 sec)

root@database-one 13:47: [gftest]> show variables like '%scheduler%';

+-----------------+-------+

| Variable_name | Value |

+-----------------+-------+

| event_scheduler | ON |

+-----------------+-------+

1 row in set (0.01 sec)

root@database-one 13:47: [gftest]> show processlist;

+--------+-----------------+----------------------+-----------+---------+------+------------------------+------------------+

| Id | User | Host | db | Command | Time | State | Info |

+--------+-----------------+----------------------+-----------+---------+------+------------------------+------------------+

......

| 121430 | event_scheduler | localhost | NULL | Daemon | 33 | Waiting on empty queue | NULL |

......

+--------+-----------------+----------------------+-----------+---------+------+------------------------+------------------+

246 rows in set (0.01 sec)

可以看到,默认情况下,MySQL的EVENT没有打开,通过设置event_scheduler参数来打开或者关闭EVENT。打开后就会多一个event_scheduler,这个就是事件调度器线程。

除了打开和关闭,还可以禁用,要禁用EVENT,请使用以下两种方法之一:

启动MySQL时用命令行参数

--event-scheduler=DISABLED

在MySQL配置文件中配置参数

event_scheduler=DISABLED

MySQL 5.7中创建EVENT的完整语法如下:

CREATE

[DEFINER = user]

EVENT

[IF NOT EXISTS]

event_name

ON SCHEDULE schedule

[ON COMPLETION [NOT] PRESERVE]

[ENABLE | DISABLE | DISABLE ON SLAVE]

[COMMENT 'string']

DO event_body;

schedule:

AT timestamp [+ INTERVAL interval] ...

| EVERY interval

[STARTS timestamp [+ INTERVAL interval] ...]

[ENDS timestamp [+ INTERVAL interval] ...]

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)创建一张表。

root@database-one 13:47: [gftest]> create table testevent(id int auto_increment primary key,create_time datetime);

Query OK, 0 rows affected (0.01 sec)

root@database-one 13:50: [gftest]> select * from testevent;

Empty set (0.00 sec)

2)创建一个EVENT,每3秒往表中插一条记录。

root@database-one 13:50: [gftest]> create event insert_date_testevent on schedule every 3 second do

-> insert into testevent(create_time) values(now());

Query OK, 0 rows affected (0.01 sec)

root@database-one 13:53: [gftest]> show events \G

*************************** 1. row ***************************

Db: gftest

Name: insert_date_testevent

Definer: root@%

Time zone: +08:00

Type: RECURRING

Execute at: NULL

Interval value: 3

Interval field: SECOND

Starts: 2020-03-26 13:53:10

Ends: NULL

Status: ENABLED

Originator: 1303306

character_set_client: utf8

collation_connection: utf8_general_ci

Database Collation: utf8_general_ci

1 row in set (0.00 sec)

3)过一会,去表中查询数据。

root@database-one 13:53: [gftest]> select * from testevent;

+----+---------------------+

| id | create_time |

+----+---------------------+

| 1 | 2020-03-26 13:53:10 |

| 2 | 2020-03-26 13:53:13 |

| 3 | 2020-03-26 13:53:16 |

| 4 | 2020-03-26 13:53:19 |

| 5 | 2020-03-26 13:53:22 |

| 6 | 2020-03-26 13:53:25 |

| 7 | 2020-03-26 13:53:28 |

| 8 | 2020-03-26 13:53:31 |

| 9 | 2020-03-26 13:53:34 |

| 10 | 2020-03-26 13:53:37 |

| 11 | 2020-03-26 13:53:40 |

| 12 | 2020-03-26 13:53:43 |

| 13 | 2020-03-26 13:53:46 |

| 14 | 2020-03-26 13:53:49 |

| 15 | 2020-03-26 13:53:52 |

| 16 | 2020-03-26 13:53:55 |

+----+---------------------+

16 rows in set (0.00 sec)

从表里数据可以看到,创建的插数定时任务已经在正常运行了。

EVENT的详细信息除了用show event命令,还可以从mysql.event或information_schema.events中查询,也可以用show create event命令查看。

root@database-one 00:09: [gftest]> select * from mysql.event \G

*************************** 1. row ***************************

db: gftest

name: insert_date_testevent

body: insert into testevent(create_time) values(now())

definer: root@%

execute_at: NULL

interval_value: 3

interval_field: SECOND

created: 2020-03-26 13:53:10

modified: 2020-03-26 13:53:10

last_executed: 2020-03-26 16:09:37

starts: 2020-03-26 05:53:10

ends: NULL

status: ENABLED

on_completion: DROP

sql_mode: ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

comment:

originator: 1303306

time_zone: +08:00

character_set_client: utf8

collation_connection: utf8_general_ci

db_collation: utf8_general_ci

body_utf8: insert into testevent(create_time) values(now())

1 row in set (0.00 sec)

root@database-one 00:09: [gftest]> select * from information_schema.events \G

*************************** 1. row ***************************

EVENT_CATALOG: def

EVENT_SCHEMA: gftest

EVENT_NAME: insert_date_testevent

DEFINER: root@%

TIME_ZONE: +08:00

EVENT_BODY: SQL

EVENT_DEFINITION: insert into testevent(create_time) values(now())

EVENT_TYPE: RECURRING

EXECUTE_AT: NULL

INTERVAL_VALUE: 3

INTERVAL_FIELD: SECOND

SQL_MODE: ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

STARTS: 2020-03-26 13:53:10

ENDS: NULL

STATUS: ENABLED

ON_COMPLETION: NOT PRESERVE

CREATED: 2020-03-26 13:53:10

LAST_ALTERED: 2020-03-26 13:53:10

LAST_EXECUTED: 2020-03-27 00:10:22

EVENT_COMMENT:

ORIGINATOR: 1303306

CHARACTER_SET_CLIENT: utf8

COLLATION_CONNECTION: utf8_general_ci

DATABASE_COLLATION: utf8_general_ci

1 row in set (0.02 sec)

root@database-one 00:10: [gftest]> show create event insert_date_testevent \G

*************************** 1. row ***************************

Event: insert_date_testevent

sql_mode: ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

time_zone: +08:00

Create Event: CREATE DEFINER=`root`@`%` EVENT `insert_date_testevent` ON SCHEDULE EVERY 3 SECOND STARTS '2020-03-26 13:53:10' ON COMPLETION NOT PRESERVE ENABLE DO insert into testevent(create_time) values(now())

character_set_client: utf8

collation_connection: utf8_general_ci

Database Collation: utf8_general_ci

1 row in set (0.00 sec)

mysql originator_MySQL中的事件调度器EVENT相关推荐

  1. 一文详解MySQL中的事件调度器EVENT

    MySQL中的事件调度器,EVENT,也叫定时任务,类似于Unix crontab或Windows任务调度程序. EVENT由其名称和所在的schema唯一标识. EVENT根据计划执行特定操作.操作 ...

  2. mysql 事件 day hour_Mysql事件调度器(Event Scheduler)

    Mysql中的事件调度器Event Scheduler类似于linux下的crontab计划任务的功能,它是由一个特殊的时间调度线程执行的 一.查看当前是否开启了event scheduler三种方法 ...

  3. mysql事件调度定时任务_详解MySQL用事件调度器Event Scheduler创建定时任务

    前言 事件调度器相当于操作系统中的定时任务(如:Linux中的cron.Window中的计划任务),但MySql的事件调度器可以精确到秒,对于一些实时性要求较高的数据处理非常有用. 1. 创建/修改事 ...

  4. mysql查看执行计划任务_MySQL_MySQL计划任务(事件调度器) Event Scheduler介绍,要查看当前是否已开启事件调 - phpStudy...

    MySQL计划任务(事件调度器) Event Scheduler介绍 要查看当前是否已开启事件调度器,可执行如下SQL: SHOW VARIABLES LIKE 'event_scheduler'; ...

  5. [MySQL 5.1 体验]MySQL 事件调度器(Event Scheduler)

    作/译者:叶金荣(Email: ),来源:http://imysql.cn,转载请注明作/译者和出处,并且不能用于商业用途,违者必究. 一.概述 事件调度器是在 MySQL 5.1 中新增的另一个特色 ...

  6. MySQL事件调度器(Event Scheduler)介绍

    事件调度器是在 MySQL 5.1 中新增的另一个特色功能,可以作为定时任务调度器,取代部分原先只能用操作系统任务调度器才能完成的定时功能.而且 MySQL 的事件调度器可以实现每秒钟执行一个任务,这 ...

  7. mysql 事件调度器_【MySQL】事件调度器 (Event Scheduler)

    一 event 介绍 事件调度器是定时触发执行的,在这个角度上也可以称作是"临时的触发器".触发器只是针对某个表产生的事件执行一些语句,而事件调度器则是在某一个(间隔)时间执行一些 ...

  8. php 事件调度,MySQL的事件调度器使用介绍

    自MySQL5.1.0起,增加了一个非常有特色的功能ndash;事件调度器(Event Scheduler),可以用做定时执行某些特定任务,可以看作基于 自MySQL5.1.0起,增加了一个非常有特色 ...

  9. mysql 数据库event_mysql数据库事件调度(Event)

    Oracle数据库监控软件(简称Oracle监控或Oracle监控软件)是企事业单位中最重要的监控需要,通过对Oracle数据库的监控,可以全面了解Oracle的运行状态.数据库响应情况.数据库表空用 ...

最新文章

  1. ##自定义一个自动注入Log 的 插件
  2. vue的js文件中获取vue实例
  3. 如何在零停机的情况下迁移 Kubernetes 集群
  4. Javascript 程序放在哪
  5. java 图片分割_Java atlas图集分割
  6. postman模拟post请求的四种请求体
  7. centos java发送邮件发不出去_传真机发不出传真怎么办 传真机发不出传真解决方法【详解】...
  8. 用java做出两行三列的表格_Java中,使用HSSFSheet创建excel模板如何创建一列两行的数据?...
  9. 求数字序列中的第n位对应的数字
  10. 红旗linux as4,可能是史上最完美的IC5141安装说明档(RHEL-AS4)
  11. linux---基础03
  12. python 下载文件-用python下载文件的若干种方法汇总
  13. 在苹果Mac中如何不用鼠标刪除文件?
  14. 点分十进制ip地址的理解
  15. 迁移学习—Geodesic Flow Kernel for Unsupervised Domain Adaptation
  16. 软件license授权加、解密,软件注册工具(2)
  17. 【CSS3盒子模型新样式】boder-box
  18. JAVA 将唐诗按照古文样式输出
  19. [论文] Feature Squeezing:Detecting Adversarial Examples in Deep Neural Networks
  20. 算法--二分查找(python实现)

热门文章

  1. Python基础,Hello,world
  2. java解析页面table表格内容导出为excel
  3. 20个非常有用的Java程序片段
  4. LeetCode: Max Points on a Line
  5. src源代码生成html格式文档
  6. js 输出中文乱码 解决办法
  7. 临近期末,图书管理系统课设项目安排上(附源码)
  8. NLineInputFormat案例
  9. 情感分析——深入snownlp原理和实践
  10. Windows10系统的使用小技巧四 —— 剪贴板历史记录