一、事件(EVENT)是干什么的
自MySQL5.1.6
起,增加了一个非常有特色的功能 – 事件调度器
(Event Scheduler),可以用做定时执行某些特定任务(例如:删除记录、数据统计报告、数据备份等等),来取代原先只能由操作系统的计划任务来执行的工作。
值得一提的是MySQL的事件调度器可以精确到每秒钟执行一个任务,而操作系统的计划任务(如:Linux的cron)只能精确到每分钟执行一次。对于一些对数据实时性要求比较高的应用(例如:股票、赔率、比分等)就非常适合。
事件有时也可以称为临时触发器(temporal triggers),因为事件调度器是基于特定时间周期触发来执行某些任务,而触发器(Triggers)是基于某个表所产生的事件触发的,区别也就在这里。
二、开启“事件”功能
使用“事件”功能之前必须确保event_scheduler已开启
1、查询功能是否开启:
-- 方法一 SELECT @@event_scheduler; -- 方法二 SHOW VARIABLES LIKE 'event%';
显示 “ON”说明功能已开启;如下图:
mysql> SELECT @@event_scheduler; +-------------------+ | @@event_scheduler | +-------------------+ | ON | +-------------------+ 1 row in set (0.00 sec) mysql> SHOW VARIABLES LIKE 'event%'; +-----------------+-------+ | Variable_name | Value | +-----------------+-------+ | event_scheduler | ON | +-----------------+-------+ 1 row in set (0.00 sec)
2、开启、关闭功能命令:
-- 开启功能命令: SET GLOBAL event_scheduler = 1; SET GLOBAL event_scheduler = ON; -- 关闭功能命令: SET GLOBAL event_scheduler = 0; SET GLOBAL event_scheduler = OFF;
当然,通过命令开启当数据库重启后会自动关闭;
持久化开启方式
:将event_scheduler=1
写到my.cnf配置文件中;如下图:
常用的事件操作命令:
- 关闭指定事件: ALTER EVENT 事件名称 ON COMPLETION PRESERVE DISABLE;
- 开启指定事件:ALTER EVENT 事件名称 ON COMPLETION PRESERVE ENABLE;
- 查看当前事件:SHOW EVENTS ;
三、事件 – SQL语法创建
下面是EVENT事件创建语句,乍一看挺复杂的,让我们拆开解读一下
CREATE EVENT [IFNOT EXISTS] event_name ON SCHEDULE schedule(调度时间设置) [ON COMPLETION [NOT] PRESERVE] [ENABLE | DISABLE | DISABLE ON SLAVE] [COMMENT 'comment'] DO sql_statement;
SQL语法 | 说明 |
---|---|
DEFINER | 可选项,给指定用户使用权限 |
IF NOT EXISTS | 可选项,用于判断要创建的事件是否存在 |
EVENT event_name | 必选项,指定事件名称,event_name的最大长度为64个字符,如果为指定event_name,则默认为当前的MySQL用户名(不区分大小写) |
ON SCHEDULE schedule | 必选项,这里的schedule用于定义执行的时间和时间间隔,在下面我们详细讲解 |
ON COMPLETION [NOT] PRESERVE | 可选项,配置事件执行完一次后的处理方式; 当为on completion pr本文来源gao@daima#com搞(%代@#码网eserve 的时候,当event到期了,event会被disable,但是该event还是会存在 当为on completion not preserve的时候,当event到期的时候,该event会被自动删除掉. |
ENABLE、DISABLE、DISABLE ON SLAVE | 可选项,用于指定事件的一种属性。 ENABLE表示该事件是开启的,也就是调度器检查事件是否必选调用; DISABLE表示该事件是关闭的,也就是事件的声明存储到目录中,但是调度器不会检查它是否应该调用; DISABLE ON SLAVE表示事件在从机中是关闭的。如果不指定这三个选择中的任意一个,则在一个事件创建之后,它立即变为活动的。 |
COMMENT ‘comment’ | 可选项,用于定义事件的注释 |
DO event_body | 必选项,用于指定事件启动时所要执行的代码。可以是任何有效的SQL语句、存储过程或者一个计划执行的事件。如果包含多条语句,可以使用BEGIN…END复合结构 |