mysql event

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: eventevent 类似 oracle job 功能, linux crontab 任务 从 MySQL 5.1.12 开始被支持 默认系统关闭该功能 root@localhost[(none)]>show variables like 'event%'; +-----------------+-------+ | Variable_name   | Value |
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数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
SQL 监控 关系型数据库
Mysql主从同步报错解决:Error executing row event: Table zabbix.history-..
Mysql主从同步报错解决:Error executing row event: Table zabbix.history-..
290 0
|
存储 SQL 关系型数据库
mysql的event定时任务
mysql的event定时任务
531 0
|
SQL 关系型数据库 MySQL
|
SQL 关系型数据库 MySQL
|
SQL 关系型数据库 MySQL
随笔:MySQL:双主情况下跳过Event的方式
简单记录如下: 双主情况下跳过相同server id Event的方式: IO线程 通过对比SERVER_ID 进行跳过操作 { mi->set_master_log_pos(mi->get_master_log_pos() + inc_pos); memcpy(r...
637 0
|
关系型数据库 MySQL 数据库
MySQL数据库 Event 定时执行任务.
一、背景   由于项目的业务是不断往前跑的,所以难免数据库的表的量会越来越庞大,不断的挤占硬盘空间。即使再大的空间也支撑不起业务的增长,所以定期删除不必要的数据是很有必要的。在我们项目中由于不清理数据,一个表占的空间竟然达到了4G之多。
1558 0
|
Web App开发 关系型数据库 MySQL