【MySQL】事件调度器 (Event Scheduler)

 一 event 介绍    

    事件调度器是定时触发执行的,在这个角度上也可以称作是"临时的触发器"。触发器只是针对某个表产生的事件执行一些语句,而事件调度器则是在某一个(间隔)时间执行一些语句。事件是由一个特定的线程来管理的,也就是所谓的"事件调度器"。启用事件调度器后,拥有 SUPER 权限的账户执行 SHOW PROCESSLIST 就可以看到这个线程了。通过设定全局变量event_scheduler 的值即可动态的控制事件调度器是否启用。

在使用这个功能之前必须确保event_scheduler已开启,可执行

SET GLOBAL event_scheduler = 1;

SET GLOBAL event_scheduler = on;

设置成功之后,执行show proceslist;

root@127.0.0.1 : (none) 11:56:09> show variables like '%event_scheduler%';

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

| Variable_name   | Value |

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

| event_scheduler | OFF   |

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

1 row in set (0.01 sec)

root@127.0.0.1 : (none) 11:56:30> SET GLOBAL event_scheduler = 1;

Query OK, 0 rows affected (0.03 sec)

root@127.0.0.1 : (none) 11:56:41> show variables like '%event_scheduler%';

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

| Variable_name   | Value |

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

| event_scheduler | ON    |

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

1 row in set (0.01 sec)

root@127.0.0.1 : (none) 11:59:57> show processlist;

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

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

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

| 165933 | root            | localhost:34672 | NULL | Query   |    0 | NULL                   | show processlist |

| 165934 | event_scheduler | localhost       | NULL | Daemon  |  204 | Waiting on empty queue | NULL             |

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

2 rows in set (0.00 sec)

进程中会出现一个event_scheduler的用户用于执行调度事件。

二、创建事件 

create evnet  [if not exists] event_name

    on schedule schedule

    [on completion [not] preserve]

    [enable | disenable]

    [commet 'commet']

    do sql_statement;

schedule:

AT timestamp [+ interval interval] | every interval [starts timestamp] [ends timestamp]

interval:

quantity {year | quarter | month | day | hour | minute |

week | sencond | year_month | day_hour | day_minute |

day_sencond | hour_minute | hour_sencond | minute_sencond}

1) 创建一个任务每隔两秒向表插入数据

create evnet  e_tab_insert 

  on schedule every 2 sencond

  do insert into yang.evnt values (now());

2) 10天后清空evnt表:

create evnet e_10d_truct_evnt 

 on schedule at current_timestamp + interal 10 day

 do truncate table yang.evnt;

3) 2013年4月5日12点整清空evnt表:

create evnet  e_evnt_1

        on schedule at timestamp '2013-04-05 12:00:00'

        do truncate table yang.evnt;

4) 2天后开启每天定时清空evnt表,一年后停止执行:

create evnet  e_evnt_2

        on schedule every 1 day

        starts current_timestamp + interval 2 day

        ends   current_timestamp + interval 1 year

        do truncate table yang.evnt

[on completion [not] preserve]可以设置这个事件是执行一次还是持久执行,默认为not preserve。

5) 每天定时清空evnt表(只执行一次,任务完成后就终止该事件):

create evnet  e_evnt_3

        on schedule every 1 day

        on completion not preserve

        do truncate table yang.evnt

[enable | disenable]可是设置该事件创建后状态是否开启或关闭,默认为enable。

[commet 'commet']可以给该事件加上注释。

三、修改事件

alter event event_name

[on schedule schedule]

[rename to new_event_name]

[on completion [not] preserve]

[commet 'commet']

[enable | disenable]

[do sql_statement]

1) 关闭事件

alter event e_evnt disenable;

2) 开启事件

alter event e_evnt enable;

3) 将每天清空evnt表改为5天清空一次:

alter event e_evnt

        on schedule every 5 day;

四、删除事件

DROP event [IF EXISTS] event_name

五 注意事项

对于主从架构的数据库要注意将从库的任务调度关闭,以防止在主库执行了之后,从库又重复在备库进行调度evnet。

时间: 2024-11-02 06:36:09

【MySQL】事件调度器 (Event Scheduler)的相关文章

详解MySQL用事件调度器Event Scheduler创建定时任务_Mysql

前言 事件调度器相当于操作系统中的定时任务(如:Linux中的cron.Window中的计划任务),但MySql的事件调度器可以精确到秒,对于一些实时性要求较高的数据处理非常有用. 1. 创建/修改事件(EVENT) 在MySql中,创建一个新的调度器使用CREATE EVENT,其语法规则如下: CREATE [DEFINER = { user | CURRENT_USER }] EVENT [IF NOT EXISTS] event_name ON SCHEDULE schedule [ON

MySQL计划任务(事件调度器) Event Scheduler介绍_Mysql

要查看当前是否已开启事件调度器,可执行如下SQL: SHOW VARIABLES LIKE 'event_scheduler';或 SELECT @@event_scheduler;或 SHOW PROCESSLIST;若显示: +-----------------+-------+| Variable_name   | Value |+-----------------+-------+| event_scheduler | OFF   |+-----------------+-------+

MySQL事件调度器

MySQL 5.1 中新增了事件调度器这一个功能.可以实现类似于SQL Server的Job功能. 1.语法: CREATE EVENT [IF NOT EXISTS] event_nameON SCHEDULE schedule [ON COMPLETION [NOT] PRESERVE][ENABLE | DISABLE][COMMENT 'comment']DO sql_statement;View Code 其中schedule的语句可以表示为: AT TIMESTAMP [+ INTE

MySQL的事件调度器使用介绍_Mysql

自MySQL5.1.0起,增加了一个非常有特色的功能–事件调度器(Event Scheduler),可以用做定时执行某些特定任务,可以看作基于时间的触发器. 一.开启 事件调度默认是关闭的,开启可执行 复制代码 代码如下: SET GLOBAL event_scheduler=1; SET GLOBAL event_scheduler=ON; 或者在my.ini文件中加上event_scheduler=1 或者在启动命令后加上"-event_scheduler=1" 可以通过如下命令查

Event Scheduler:MySQL的事件调度器

一.概述 事件调度器是在 MySQL 5.1 中新增的另一个特色功能,可以作为定时任务调度器,取代部分原先只能 用操作系统任务调度器才能完成的定时功>能.例如,Linux 中的 crontabe 只能精确到每分钟执行一 次,而 MySQL 的事件调度器则可以实现每秒钟执行一个任务,这在一些对实时性要>求较高的环境下 就非常实用了. 事件调度器是定时触发执行的,在这个角度上也可以称作是"临时的触发器".触发器只是 针对某个表产生的事件执行一些语句,而事件调度器则是在某一个(间

MySQL Event Scheduler(事件调度器)_Mysql

一.概述 事件调度器是在 MySQL 5.1 中新增的另一个特色功能,可以作为定时任务调度器,取代部分原先只能用操作系统任务调度器才能完成的定时功>能.例如,Linux 中的 crontabe 只能精确到每分钟执行一次,而 MySQL 的事件调度器则可以实现每秒钟执行一个任务,这在一些对实时性要>求较高的环境下就非常实用了. 事件调度器是定时触发执行的,在这个角度上也可以称作是"临时的触发器".触发器只是针对某个表产生的事件执行一些语句,而事件调度器则是在某一个(间隔)时间

Atitit.js的键盘按键事件捆绑and事件调度_javascript技巧

 1. Best的方法还是 objEvtMap[ id+evt ]=function(evt,element) 2. Event bind function bindEvent_4_dataBlock() { var arr=$("#table1 li"); arr.each(function(index, element) { $(element).keypress(function(){ alert('keypress'); }); var id="data_aid_&q

mysql 定时脚本(event),类似oracle的job

我有2张表:tb_push_data 和 tb_push_data_log 现在需要每隔一段时间将tb_push_data 符合条件的数据备份到表 tb_push_data_log -------------------------------------------------------------------------- 一.创建存储过程 DELIMITER $$ USE `push_server_db`$$ DROP PROCEDURE IF EXISTS `proc_tb_push_

MySQL中的事件调度基础学习教程_Mysql

经常需要有一些定时任务在MySQL表上执行,例如统计.迁移.删除无用数据等.之前的作法是利用Linux cron定时运行脚本,但是发现这样的额外依赖有时并不方便,例如单机多实例部署时,就需要分别手动分别配置不同的cron任务,需要额外配置相应的用户和权限:新环境部署时容易遗漏cron任务等. MySQL提供了Event Scheduler,与Linux下的crontab类似,可以根据时间调度来运行任务,运行一次或多次. 完整的Event Schduler创建语句如下: CREATE [DEFIN