文档章节

mysql事件

wayhk
 wayhk
发布于 2015/05/13 14:25
字数 753
阅读 14
收藏 0

自 MySQL5.1.0起,增加了一个非常有特色的功能–事件调度器(Event Scheduler),可以用做定时执行某些特定任务(例如:删除记录、对数据进行汇总等等),来取代原先只能由操作系统的计划任务来执行的工作。更值得 一提的是MySQL的事件调度器可以精确到每秒钟执行一个任务,而操作系统的计划任务(如:Linux下的CRON或Windows下的任务计划)只能精 确到每分钟执行一次。对于一些对数据实时性要求比较高的应用(例如:股票、赔率、比分等)就非常适合。

事件调度器有时也可称为临时触发器(temporal triggers),因为事件调度器是基于特定时间周期触发来执行某些任务,而触发器(Triggers)是基于某个表所产生的事件触发的,区别也就在这里。

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

 GLOBAL event_scheduler = 1;
 ---或我们可以在配置my.ini文件 中加上 event_scheduler = 1

SET GLOBAL event_scheduler = ON;

来开启,也可以直接在启动命令加上“–event_scheduler=1”,例如:

mysqld ... --event_scheduler=1

要查看当前是否已开启事件调度器,可执行如下SQL:

SHOW VARIABLES LIKE 'event_scheduler';

SELECT @@event_scheduler;

SHOW PROCESSLIST;

二、创建事件(CREATE EVENT)

先来看一下它的语法:

 EVENT [IF  ] event_name
 ON SCHEDULE schedule
 [ON COMPLETION [] PRESERVE]
 [ENABLE | DISABLE]
 [COMMENT 'comment']
  sql_statement;
 
schedule:
 AT  [+  ]
 | EVERY  [STARTS ] [ENDS ]
 
:
 quantity { |  |  |  |  |  |
  |  |

1) 首先来看一个简单的例子来演示每秒插入一条记录到数据表

 test;
 aaa (timeline );
 EVENT e_test_insert
 ON SCHEDULE EVERY 1  
    test.aaa  ();

等待3秒钟后,再执行查询看看:

mysql>  *  aaa;
+
| timeline | 
+
| 2007-07-18 20:44:26 | 
| 2007-07-18 20:44:27 | 
| 2007-07-18 20:44:28 | 
+

2) 5天后清空test表:

 EVENT e_test
 ON SCHEDULE AT  +  5 
   TABLE test.aaa;

3) 2007年7月20日12点整清空test表:

 EVENT e_test
 ON SCHEDULE AT  '2007-07-20 12:00:00'
   TABLE test.aaa;

4) 每天定时清空test表:

 EVENT e_test
 ON SCHEDULE EVERY 1 
   TABLE test.aaa;

5) 5天后开启每天定时清空test表:

 EVENT e_test
 ON SCHEDULE EVERY 1 
 STARTS  +  5 
   TABLE test.aaa;

6) 每天定时清空test表,5天后停止执行:

 EVENT e_test
 ON SCHEDULE EVERY 1 
 ENDS  +  5 
   TABLE test.aaa;

7) 5天后开启每天定时清空test表,一个月后停止执行:

 EVENT e_test
 ON SCHEDULE EVERY 1 
 STARTS  +  5 
 ENDS  +  1 
   TABLE test.aaa;

[ON COMPLETION [NOT] PRESERVE]可以设置这个事件是执行一次还是持久执行,默认为NOT PRESERVE。
8) 每天定时清空test表(只执行一次,任务完成后就终止该事件):

 EVENT e_test
 ON SCHEDULE EVERY 1 
 ON COMPLETION  PRESERVE
   TABLE test.aaa;

[ENABLE | DISABLE]可是设置该事件创建后状态是否开启或关闭,默认为ENABLE。
[COMMENT ‘comment’]可以给该事件加上注释。

三、修改事件(ALTER EVENT)

 EVENT event_name
 [ON SCHEDULE schedule]
 [RENAME TO new_event_name]
 [ON COMPLETION [] PRESERVE]
 [COMMENT 'comment']
 [ENABLE | DISABLE]
 [ sql_statement]

1) 临时关闭事件

ALTER EVENT e_test DISABLE;

2) 开启事件

ALTER EVENT e_test ENABLE;

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

 EVENT e_test

     

 



© 著作权归作者所有

共有 人打赏支持
wayhk
粉丝 1
博文 36
码字总数 17367
作品 0
海淀
程序员
jfinal c3p0 mysql相关的问题

事件类型: 警告 事件来源: MySQL 事件种类: 无 事件 ID: 100 日期: 2013-7-16 事件: 13:08:53 用户: N/A 计算机: 描述: D:MySQLMySQL Server 5.5binmysqld: Forcing close of thread 6611 us......

lile-chs
2013/07/16
318
7
jfinal使用c3p0连接mysql数据库,连接线程time_wait问题

在使用过程中,发现系统日志显示警告 事件类型: 警告 事件来源: MySQL 事件种类: 无 事件 ID: 100 日期: 2013-7-16 事件: 13:08:53 用户: N/A 计算机: 描述: D:MySQLMySQL Server 5.5binmys...

lile-chs
2013/07/18
0
0
MySQL-Binlog V0.7 发布

什么是MySQL-Binlog MySQL-Binlog 连接到 MySQL 数据库,基于 Netty 框架,实时解析MySQL的二进制日志binlog而非定时查询数据库, 提取出用户级感兴趣的事件:INSERT,UPDATE,DELETE,供后续分析...

强子哥哥
2016/04/17
2.1K
0
MySQL的事件调度器使用介绍

MySQL的事件调度器使用介绍 自MySQL5.1.0起,增加了一个非常有特色的功能–事件调度器(Event Scheduler),可以用做定时执行某些特定任务,可以看作基于时间的触发器。 一、开启 事件调度默认...

开元中国2015
2015/06/25
66
0
mysql复制的工作原理及主从复制的实现

mysql的复制功能主要有3个步骤 主服务器将改变记录到二进制日志中,(这些记录叫做二进制日志事件) 从服务器将主服务器的二进制日志事件拷贝到它的中继日志中 从服务器重做中继日志中的事件...

雾中花1
2017/11/24
0
0

没有更多内容

加载失败,请刷新页面

加载更多

kubeadm部署kubernetes集群

一、环境要求 这里使用RHEL7.5 master、etcd:192.168.10.101,主机名:master node1:192.168.10.103,主机名:node1 node2:192.168.10.104,主机名:node2 所有机子能基于主机名通信,编辑...

人在艹木中
39分钟前
2
0
Shell特殊符号总结以及cut,sort,wc,uniq,tee,tr,split命令

特殊符号总结一 * 任意个任意字符 ? 任意一个字符 # 注释字符 \ 脱义字符 | 管道符 # #号后的备注被忽略[root@centos01 ~]# ls a.txt # 备注 a.txt[root@centos01 ~]# a=1[root@centos01...

野雪球
今天
2
0
OSChina 周二乱弹 —— 程序员圣衣

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @达尔文:分享Skeeter Davis的单曲《The End of the World》 《The End of the World》- Skeeter Davis 手机党少年们想听歌,请使劲儿戳(这里...

小小编辑
今天
14
0
[ python import module ] 导入模块

import moudle_name ----> import module_name.py ---> import module_name.py文件路径 -----> sys.path (这里进行查找文件) # from app.web import Personimport app.web.Person as Pe......

_______-
昨天
5
0
Redis性能问题排查解决手册

一、性能相关的数据指标 通过Redis-cli命令行界面访问到Redis服务器,然后使用info命令获取所有与Redis服务相关的信息。通过这些信息来分析文章后面提到的一些性能指标。 nfo命令输出的数据可...

IT--小哥
昨天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部