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}

详细说明可以参考官网https://dev.mysql.com/doc/refman/5.7/en/create-event.html

我们通过一个实例来验证下。
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: 1303306character_set_client: utf8collation_connection: utf8_general_ci  Database Collation: utf8_general_ci1 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: gftestname: insert_date_testeventbody: insert into testevent(create_time) values(now())definer: root@%execute_at: NULLinterval_value: 3interval_field: SECONDcreated: 2020-03-26 13:53:10modified: 2020-03-26 13:53:10last_executed: 2020-03-26 16:09:37starts: 2020-03-26 05:53:10ends: NULLstatus: ENABLEDon_completion: DROPsql_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_SUBSTITUTIONcomment:originator: 1303306time_zone: +08:00
character_set_client: utf8
collation_connection: utf8_general_cidb_collation: utf8_general_cibody_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: defEVENT_SCHEMA: gftestEVENT_NAME: insert_date_testeventDEFINER: root@%TIME_ZONE: +08:00EVENT_BODY: SQLEVENT_DEFINITION: insert into testevent(create_time) values(now())EVENT_TYPE: RECURRINGEXECUTE_AT: NULLINTERVAL_VALUE: 3INTERVAL_FIELD: SECONDSQL_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_SUBSTITUTIONSTARTS: 2020-03-26 13:53:10ENDS: NULLSTATUS: ENABLEDON_COMPLETION: NOT PRESERVECREATED: 2020-03-26 13:53:10LAST_ALTERED: 2020-03-26 13:53:10LAST_EXECUTED: 2020-03-27 00:10:22EVENT_COMMENT:ORIGINATOR: 1303306
CHARACTER_SET_CLIENT: utf8
COLLATION_CONNECTION: utf8_general_ciDATABASE_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_testeventsql_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_SUBSTITUTIONtime_zone: +08:00Create 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_ciDatabase Collation: utf8_general_ci
1 row in set (0.00 sec)

墨天轮原文链接:https://www.modb.pro/db/23162(复制到浏览器中打开或者点击“阅读原文”)

推荐阅读:144页!分享珍藏已久的数据库技术年刊


点击下图查看更多 ↓

云和恩墨大讲堂 | 一个分享交流的地方

长按,识别二维码,加入万人交流社群

请备注:云和恩墨大讲堂

  点个“在看”

你的喜欢会被看到❤

一文详解MySQL中的事件调度器EVENT相关推荐

  1. mysql originator_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_MySQL计划任务(事件调度器) Event Scheduler介绍,要查看当前是否已开启事件调 - phpStudy...

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

  4. mysql的json函数与实例_Mysql实例详解Mysql中的JSON系列操作函数

    <Mysql实例详解Mysql中的JSON系列操作函数>要点: 本文介绍了Mysql实例详解Mysql中的JSON系列操作函数,希望对您有用.如果有疑问,可以联系我们. MYSQL必读前言 ...

  5. 一文详解编程中的随机数

    一文详解编程中的随机数 随机数的类型 真随机数生成器 TRNG - True Random Number Generator 伪随机数生成器 PRNG - Pseudo Random Number G ...

  6. mysql 事物的持久性是指_详解MySQL中事务的持久性实现原理

    前言 说到数据库事务,大家脑子里一定很容易蹦出一堆事务的相关知识,如事务的ACID特性,隔离级别,解决的问题(脏读,不可重复读,幻读)等等,但是可能很少有人真正的清楚事务的这些特性又是怎么实现的,为什 ...

  7. mysql_slow_详解MySQL中SlowLog的配置方法(图文)

    mysql 日志系统上线有段时间了,前端在慢慢切站点过来写入,未雨绸缪 diy了套 mysql 监控工具. 分为 slave  status ,sync,objec infot,userprivile ...

  8. mysql 日期比较_详解Mysql中日期比较大小的方法

    假如有个表product有个字段add_time,它的数据类型为datetime,有人可能会这样写sql: 代码如下 select * from product where add_time = '2 ...

  9. 详解Mysql中日期比较大小的方法

    假如有个表product有个字段add_time,它的数据类型为datetime,有人可能会这样写sql: 代码如下 select * from product where add_time = '2 ...

最新文章

  1. 前端学习路线_前端学习路线图
  2. linux2.6.37内核接两个硬盘导致读写效率变低的问题
  3. 合理提升WEB前端性能
  4. Java程序员的10个XML面试问答
  5. Android--Pin流程,飞行模式相关流程总结【工作日记一】
  6. 路透:在美投资遇阻 中国科技资金转向以色列
  7. GitHub 给已存在的仓库增加开原协议LICENSE
  8. 解决mysql客户端中文显示乱码
  9. 大型电子病历系统【整套源代码分享】
  10. 惠普服务器硬盘指示灯不亮或显示蓝色
  11. 网站建设html代码优化,网站设计代码优化让网站打开速度飞起来
  12. 1 EXCEL数据分析常用函数
  13. 实现一个B站弹幕不挡人物的效果
  14. Access用户如何借助低代码转型为Web(B/S和移动端)开发?
  15. C# 简单图片爬虫 快来斗图把
  16. SAR数据地物变化监测
  17. Ubuntu配置静态IP地址
  18. 电容笔做的比较好的品牌有哪些?好用电容笔测评
  19. 如何使用 mps 开发原生小程序
  20. 2020.08.06狂人日记:Python项目转C#项目问题

热门文章

  1. 360安全路由器v2处理器_您的路由器有多不安全?
  2. ansible 并发设置_如何使用Ansible通过Prometheus设置系统监视
  3. libreoffice使用_使用LibreOffice Calc管理您的财务
  4. 开源 协作工具_6所高等学校教授开源,协作峰会的言论以及更多新闻
  5. JavaScript_Object.assign(目标对象,源对象1,源对象2,...)
  6. Bootstrap3 表格的情景类
  7. es6 SharedArrayBuffer对象
  8. 修复共享服务器,【转】Exadata存储服务器的紧急修复(rescue)经验分享
  9. android开启热点softap模式,[RK3288][Android6.0] Wifi开启热点(SoftAP)流程小结
  10. java百度地图坐标_java腾讯地图与百度地图坐标转换