美文网首页mysql
(014)mysql中的事件

(014)mysql中的事件

作者: 林湾村龙猫 | 来源:发表于2016-01-21 00:44 被阅读388次

概述

事件调度器是MySQL5.1后新增的功能,可以将数据库按自定义的时间周期触发某种操作,可以理解为时间触发器,类似于linux系统下面的任务调度器crontab,或者类似与window下面的计划任务。值得一提的是MySQL的事件调度器可以精确到每秒钟执行一个任务,而操作系统的计划任务(如:Linux下的CRON或Windows下的任务计划)只能精确到每分钟执行一次。

查看事件功能是否开启

在使用事件这个功能,首先要保证你的mysql的版本是5.1以上,然后还要查看你的mysql服务器上的事件是否开启。
查看事件是否开启,使用如下命令查看:

#方式一
SHOW VARIABLES LIKE 'event_scheduler';
#方式二
SELECT @@event_scheduler;
#方式三
SHOW PROCESSLIST;

#查看事件状态
SHOW EVENTS;

如果看到event_scheduler为on或者PROCESSLIST中显示有event_scheduler的信息说明就已经开启了事件。如果显示为off或者在PROCESSLIST中查看不到event_scheduler的信息,那么就说明事件没有开启,我们需要开启它。

开启事件功能

方式一、通过动态参数修改

SET GLOBAL event_scheduler = ON;

更改完这个参数就立刻生效了,但是重启mysql又还原了,即设置不能跨重启。
方式二、更改配置文件然后重启
在my.cnf中的[mysqld]部分添加如下内容,然后重启mysql。

event_scheduler=ON;

一劳永逸,需要能够修改数据库配置的权限。

方式三、直接在启动命令加上“–event_scheduler=1”

mysqld ... --event_scheduler=ON

事件的语法

1. 创建事件

CREATE
    [DEFINER = { user | CURRENT_USER }]
    EVENT
    [IF NOT EXISTS]
    event_name
    ON SCHEDULE schedule
    [ON COMPLETION [NOT] PRESERVE]
    [ENABLE | DISABLE | DISABLE ON SLAVE]
    [COMMENT 'comment']
    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}

DEFINER: 定义事件执行的时候检查权限的用户。
ON SCHEDULE schedule: 定义执行的时间和时间间隔。
ON COMPLETION [NOT] PRESERVE: 定义事件是一次执行还是永久执行,默认为一次执行,即NOT PRESERVE。
ENABLE | DISABLE | DISABLE ON SLAVE: 定义事件创建以后是开启还是关闭,以及在从上关闭。如果是从服务器自动同步主上的创建事件的语句的话,会自动加上DISABLE ON SLAVE。
COMMENT 'comment': 定义事件的注释。

2. 更改事件

ALTER
    [DEFINER = { user | CURRENT_USER }]
    EVENT event_name
    [ON SCHEDULE schedule]
    [ON COMPLETION [NOT] PRESERVE]
    [RENAME TO new_event_name]
    [ENABLE | DISABLE | DISABLE ON SLAVE]
    [COMMENT 'comment']
    [DO event_body]

3. 删除事件的语法

DROP EVENT [IF EXISTS] event_name;

事件使用举例

1. 创建事件

举例一
定时每隔3秒向表test2中插入数据

create event event_insert_t2
on schedule every 3 second
on completion preserve
do insert into test2(department,time_v) value('1',now());

执行结果


事件执行结果

举例二
创建一个10分钟后清空test表数据的事件

CREATE EVENT IF NOT EXISTS event_truncate_test2
ON SCHEDULE
AT CURRENT_TIMESTAMP + INTERVAL 10 MINUTE
DO TRUNCATE TABLE test2;

举例三
创建一个在2015-04-17 14:42:00时刻清空test表数据的事件

DROP EVENT IF EXISTS event_truncate_test2;
CREATE EVENT event_truncate_test2
ON SCHEDULE
AT TIMESTAMP '2015-04-17 14:42:00'
DO TRUNCATE TABLE test2;

举例四
5天后开启每天定时3秒向表test2中插入数据,一个月后停止执行

CREATE EVENT IF NOT EXISTS event_truncate_test2
ON SCHEDULE EVERY 3 SECOND
STARTS CURRENT_TIMESTAMP + INTERVAL 5 day
ENDS CURRENT_TIMESTAMP + INTERVAL  1 month
ON COMPLETION PRESERVE
DO INSERT INTO test2(department,time_v) VALUES('1',NOW());

修改事件举例

举例一
临时关闭事件

alter event event_insert_t2 disable;

其他类似创建事件。

删除事件举例

DROP EVENT IF EXISTS event_insert_t2;

事件调用存储过程或函数如同普通调用。

事件的优缺点及应用场景

  1. 优点
  • 定时任务由dba统一管理,避免部署在操作系统层。
  • 减少系统管理员产生误操作的风险。
  • 有利于后续的管理和维护。
  1. 缺点
  • 在繁忙且要求性能的数据库上慎重部署和启用调度器。
  • 过于复杂的处理更适合使用程序实现。
  • 开启和关闭事件需要具有超级用户权限。
  1. 应用场景
    适用于定期收集统计信息,定期清除历史数据,定期数据库检查等等。

参考

http://blog.163.com/duanpeng3@126/blog/static/8854373520105182123112/
http://blog.chinaunix.net/uid-20639775-id-3323098.html

相关文章

  • (014)mysql中的事件

    概述 事件调度器是MySQL5.1后新增的功能,可以将数据库按自定义的时间周期触发某种操作,可以理解为时间触发器,...

  • NIFI-CaptureChangeMySQL-mysqlBin

    1.简介 从MySQL数据库中检索更改数据捕获(CDC)事件。CDC事件包括插入、更新、删除操作。事件作为单独的流...

  • mysql查看事件是否开启,设置启动时自动开启方法

    1.查看事件是否开启 2.设置当前事件开启 3.设置事件在mysql启动时自动开启方法 我们先开启mysql事件,...

  • mysql event事件执行(navicate))

    参考链接 mysql事件每天执行一次_MySQL-事件https://blog.csdn.net/weixin_2...

  • MySQL BinLog-2020-02

    MySQL binlog的几种日志录入格式以及区别binlog文件中存储的内容称之为二进制事件,简称事件。我们的每...

  • mysql 事件调度event_scheduler

    mysql自身提供了定时调度的功能 开启关闭 MySQL事件调度器event_scheduler负责调用事件,它默...

  • MySQL的二进制日志(binlog)以及主从配置

    MySQL的二进制日志记录了所有对MySQL数据库的修改事件,包括增删改查事件和对表结构的修改事件。 1、binl...

  • MYSQL事件

    原文链接:https://www.bestqliang.com/#/article/8 1 事件简介 事件(eve...

  • MySQL 事件

    什么是事件 一组SQL集,用来执行定时任务,跟触发器很像,都是被动执行的,事件是因为时间到了触发执行,而触发器是因...

  • Mysql 事件

    1. 检查数据库事件是否开启,event_scheduler=ON表示开启 2. 开启事件 法1: 法2: 法3:...

网友评论

    本文标题:(014)mysql中的事件

    本文链接:https://www.haomeiwen.com/subject/niylkttx.html