iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL中的事件调度器EVENT是怎样的
  • 698
分享到

MySQL中的事件调度器EVENT是怎样的

2024-04-02 19:04:59 698人浏览 薄情痞子
摘要

这篇文章将为大家详细讲解有关Mysql中的事件调度器EVENT是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。mysql中的事件调度器EVENT,可以

这篇文章将为大家详细讲解有关Mysql中的事件调度器EVENT是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

mysql中的事件调度器EVENT,可以在数据库里按照设定的时间周期触发某些操作,类似于定时任务机制。

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: utf8
collation_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: 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:00character_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: 1303306CHARACTER_SET_CLIENT: utf8
COLLATION_CONNECTION: utf8_general_ci
  DATABASE_COLLATION: utf8_general_ci1 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_ci1 row in set (0.00 sec)

关于MySQL中的事件调度器EVENT是怎样的就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL中的事件调度器EVENT是怎样的

本文链接: https://www.lsjlt.com/news/61471.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL中的事件调度器EVENT是怎样的
    这篇文章将为大家详细讲解有关MySQL中的事件调度器EVENT是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。MySQL中的事件调度器EVENT,可以...
    99+
    2024-04-02
  • MySQL事件调度器Event Scheduler是实例介绍
    这篇文章主要介绍“MySQL事件调度器Event Scheduler是实例介绍”,在日常操作中,相信很多人在MySQL事件调度器Event Scheduler是实例介绍问题上存在疑惑,小编查阅了各式资料,整...
    99+
    2024-04-02
  • 怎么理解MySQL的EVENT事件
    这篇文章主要介绍“怎么理解MySQL的EVENT事件”,在日常操作中,相信很多人在怎么理解MySQL的EVENT事件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么理解My...
    99+
    2024-04-02
  • MySQL事件调度器的用法介绍
    本篇内容主要讲解“MySQL事件调度器的用法介绍”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL事件调度器的用法介绍”吧! 事件调度器有时也可称为临时...
    99+
    2024-04-02
  • MYSQL中怎么实现一个事件调度器
    这篇文章给大家介绍MYSQL中怎么实现一个事件调度器,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1.查看是否开启:mysql> show variables like '...
    99+
    2024-04-02
  • python包中的sched事件调度器怎么用
    本篇内容主要讲解“python包中的sched事件调度器怎么用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“python包中的sched事件调度器怎么用”吧!一、延迟运行事件在一个延迟或规定时间...
    99+
    2023-06-30
  • mysql binlog event格式是什么样的
    mysql binlog event格式是什么样的,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。首先发起几个事务,生成一个新的...
    99+
    2024-04-02
  • MySQL故障切换中事件调度器的注意事项有哪些
    今天就跟大家聊聊有关MySQL故障切换中事件调度器的注意事项有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 &nb...
    99+
    2024-04-02
  • MySQL中的事务分析是怎样的
    MySQL中的事务分析是怎样的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。我们都知道,计算机处理的速度非常地快,但是再快的计算机,也面临...
    99+
    2024-04-02
  • Linux中Kill命令的进程调度是怎样的
    本篇文章为大家展示了Linux中Kill命令的进程调度是怎样的,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一丶进程管理Linux 是一种动态系统,能够适应不断变化的计算需求。Linux 计算需求的...
    99+
    2023-06-28
  • python 包中的sched 事件调度器的操作方法
    目录一、延迟运行事件二、重叠事件三、事件优先级四、取消事件五、其他方法一、延迟运行事件 在一个延迟或规定时间之后执行事件,需要采用enter()方法,参数如下:间隔时间 ( 具体值决...
    99+
    2024-04-02
  • MYSQL事件高度器的用法
    本篇内容介绍了“MYSQL事件高度器的用法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! 要查看...
    99+
    2024-04-02
  • MySQL中间件是怎么样的
    MySQL中间件是怎么样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 首先数据库技术发展的基础还是在业务推动的背景下,能够实现相关的技术...
    99+
    2024-04-02
  • MySQL定时任务EVENT事件的使用方法
    目录一、查看定时策略是否开启二、创建定时任务 三、定时任务操作四、定时规则一、查看定时策略是否开启 show variables like '%event_scheduler%';  * on这里是...
    99+
    2023-05-25
    MySQL定时任务EVENT事件 MySQL EVENT事件
  • Mysql存储过程、触发器、事件调度器怎么使用
    本文小编为大家详细介绍“Mysql存储过程、触发器、事件调度器怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“Mysql存储过程、触发器、事件调度器怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。存...
    99+
    2023-06-28
  • 如何使用 PHP 的 Symfony 事件调度器
    今天,我们将学习如何使用 Symfony 事件调度器组件,它允许我们在 PHP 应用程序中创建事件和侦听器。 因此,应用程序的不同组件可以通过松散耦合的代码相互通信。 什么是 Symfony 事件...
    99+
    2024-02-27
  • mysql中event的用法是什么
    在MySQL中,Event是一种用于调度在特定时间执行的操作的机制。通过创建Event,可以在数据库中定期执行一些任务,例如数据备份...
    99+
    2024-03-11
    mysql
  • react事件原理是怎样的
    react事件原理是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。一 前言今天我们来一起探讨一下React事件原理,这篇文章,我尽量用通...
    99+
    2024-04-02
  • mysql中event的作用是什么
    MySQL中的事件(Event)是一种在数据库内部实现的调度任务工具,用于执行定期性的SQL语句或存储过程。通过创建事件,您可以指定...
    99+
    2024-04-09
    mysql
  • Oracle事件驱动的调度作业
    Oracle调度作业最常见的用法是基于时间的调度,设置特定的时间调度规则,依据规则在特定的时间点触发作业程序执行,大部分的作业都是这种类型。除此之外,还可以搭建基于事件的调度作业,就是依据特定的事件来触...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作