mysql event

event
event 类似 oracle job 功能, linux crontab 任务
从 MySQL 5.1.12 开始被支持

默认系统关闭该功能

root@localhost[(none)]>show variables like 'event%';
+-----------------+-------+
| Variable_name   | Value |
+-----------------+-------+
| event_scheduler | OFF   |
+-----------------+-------+
1 row in set (0.00 sec)

修改 my.ini, 重启 mysql 或者 set global event_scheduler=on; 方法都可以启动
event_scheduler=1

授权用户创建, 修改, 丢弃事件
grant event on new.* to tt@localhost;

查询事件方法
select * from information_schema.events;
show events;
语法
CREATE
    [DEFINER = { user | CURRENT_USER }]  <- 默认 DEFINER = CURRENT_USER
    EVENT
    [IF NOT EXISTS]
    event_name
    ON SCHEDULE schedule
    [ON COMPLETION [NOT] PRESERVE] <- 通常 EVENT 过期马上丢弃 not peserve 不丢弃
[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}

测试前提 pro_del_early
create table u1 ( id int, time datetime );

delimiter //
create procedure pro_del_early()
begin
declare d1 time;
select now() - INTERVAL 1800 SECOND into d1;
delete from u1 where time < d1;
end
//
delimiter ;
时间定义
一次性执行
ON SCHEDULE  at current_timestamp + interval 4 hour
ON SCHEDULE  at current_timestamp - interval 4 hour <- 注意, 创建成功, 但不执行, 无效时间
ON SCHEDULE  at current_timestamp + interval '6:15' HOUR_MINUTE


重复每天执行
ON SCHEDULE every 1 day
ON SCHEDULE every 1 day STARTS CURRENT_TIMESTAMP + interval 4 hour
on schedule every 30 minute


指定时间范围
从 4 小时后至某个固定时间, 没隔三日开始一次
ON SCHEDULE every 3 day STARTS current_timestamp + interval 4 hour ends  "2012-11-11 11:11:00"
ON SCHEDULE every 3 day STARTS '2012-03-01 11:11:00' ends "2012-11-11 11:11:00"

on schedule EVERY 2 WEEK STARTS CURRENT_TIMESTAMP + INTERVAL '6:15' HOUR_MINUTE

on schedule EVERY 12 HOUR STARTS CURRENT_TIMESTAMP + INTERVAL 30 MINUTE
ENDS CURRENT_TIMESTAMP + INTERVAL 4 WEEK
ex1
每天当前时间执行 pro_del_early 存储过程

create event if not exists ev1
ON SCHEDULE every 1 day
do
call  pro_del_early();
ex2
一次性 当前 4 小时候执行 pro_del_early

create event if not exists ev2
ON SCHEDULE  at current_timestamp + interval 4 hour
ON COMPLETION NOT PRESERVE
enable
do 
call  pro_del_early();
ex3
每天执行, 当前时候三小时后开始

create event if not exists ev3
ON SCHEDULE   every 1 day
STARTS CURRENT_TIMESTAMP + interval 4 hour
ON COMPLETION NOT PRESERVE
enable
do 
call  pro_del_early();
ex4
每 30 分钟执行一次

create event if not exists ev4
ON SCHEDULE every 30 minute
ON COMPLETION NOT PRESERVE
enable
do 
call  pro_del_early();
ex5
两个时间段之间重复执行

create event if not exists ev5
ON SCHEDULE every 3 day STARTS '2012-03-03 11:11:00' ENDS '2012-11-11 11:11:00'
ON COMPLETION NOT PRESERVE
enable
do 
call  pro_del_early();
启用与关闭
关闭某个 schedule

alter event ev1 disable;
alter event ev1 enable;
### 如何在 MySQL 中创建和管理 EVENT #### 创建事件 (CREATE EVENT) 为了定义一个新事件,可以使用 `CREATE EVENT` 语句。该命令允许指定何时以及如何频繁触发特定操作。当创建一个新的定时器驱动的任务时,MySQL会记录下当时有效的SQL模式(`sql_mode`)并保存起来;每当这个预定任务被执行的时候都会采用最初设定的那个SQL模式来运行[^1]。 下面是一个简单的例子展示怎样建立每分钟打印一次消息到日志文件里的事件: ```sql DELIMITER $$ CREATE DEFINER=`root`@`localhost` EVENT my_event ON SCHEDULE EVERY 1 MINUTE STARTS CURRENT_TIMESTAMP DO BEGIN INSERT INTO logs VALUES (NOW(), 'This is a test message.'); END$$ DELIMITER ; ``` 这段脚本设置了名为`my_event`的新事件,它将在创建后的每一分钟执行一次,并向表`logs`插入一条包含时间戳和字符串的消息。 #### 启动/停止事件调度程序 (Event Scheduler) 默认情况下,事件调度可能处于关闭状态。要激活或停用整个系统的事件处理机制,则需修改配置参数`event_scheduler`。这可以在启动服务前通过编辑配置文件完成,比如对于Linux平台上的`my.cnf`文件而言,应该加入如下行以开启调度功能[^2]: ```ini [mysqld] event_scheduler=ON ``` 另外也可以动态调整这一选项而无需重启服务器,只需发出相应的SET GLOBAL指令即可改变全局级别的设置: ```sql SET GLOBAL event_scheduler = ON; ``` #### 故障排查与调试 如果发现已成功构建好的事件未能正常运作,那么应当查看错误日志寻找线索。通常这些信息会被写入由`log_error`所指向的位置,默认是在数据目录之下。确保路径正确无误有助于快速定位问题所在[^3]. #### 安全性和性能考量 尽管Events提供了极大的便利性,但在实际部署之前仍有必要评估它们所带来的影响。考虑到安全因素,建议仅授予必要的权限给负责维护此类对象的账户。此外,精心策划好计划任务的时间安排能够有效防止资源争用现象的发生,从而保障系统稳定高效运转[^4].
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Terry_Tsang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值