MySQL计划任务(事件调度器)

MySQL5.1.x版本中引入了一项新特性EVENT,顾名思义就是事件、定时任务机制,在指定的时间单元内执行特定的任务,因此今后一些对数据定时性操作不再依赖外部程序,而直接使用数据库本身提供的功能。

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

SHOW VARIABLES LIKE 'event_scheduler'; 或

SELECT @@event_scheduler; 或

SHOW PROCESSLIST;

若显示:

+-----------------+-------+ | Variable_name | Value | +-----------------+-------+ | event_scheduler | OFF | +-----------------+-------+ 则可执行

SET GLOBAL event_scheduler = 1; 或

SET GLOBAL event_scheduler = ON;

创建事件(CREATE EVENT) 先来看一下它的语法:

CREATE EVENT [IF NOT EXISTS] event_name ON SCHEDULE schedule [ON COMPLETION [NOT] PRESERVE] [ENABLE | DISABLE] [COMMENT 'comment'] DO sql_statement;

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

USE test; CREATE TABLE aaa (timeline TIMESTAMP); CREATE EVENT e_test_insert ON SCHEDULE EVERY 1 SECOND DO INSERT INTO test.aaa VALUES (CURRENT_TIMESTAMP); 等待3秒钟后,再执行查询成功。

修改事件(ALTER EVENT) ALTER EVENT event_name [ON SCHEDULE schedule] [RENAME TO new_event_name] [ON COMPLETION [NOT] PRESERVE] [COMMENT 'comment'] [ENABLE | DISABLE] [DO sql_statement] 1) 临时关闭事件

ALTER EVENT e_test DISABLE; 2) 开启事件

ALTER EVENT e_test ENABLE; 3) 将每天清空test表改为5天清空一次:

ALTER EVENT e_test ON SCHEDULE EVERY 5 DAY;

删除事件(DROP EVENT) 语法很简单,如下所示:

DROP EVENT [IF EXISTS] event_name 例如删除前面创建的e_test事件

DROP EVENT e_test; 当然前提是这个事件存在,否则会产生ERROR 1513 (HY000): Unknown event错误,因此最好加上IF EXISTS

DROP EVENT IF EXISTS e_test;

原文发布于微信公众号 - php(phpdaily)

原文发表时间:2014-07-29

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Objective-C

React Native 部署开发环境

3545
来自专栏Hadoop实操

如何通过Cloudera Manager为Kafka启用Kerberos及使用

在CDH集群中启用了Kerberos认证,那么我们的Kafka集群能否与Kerberos认证服务集成呢?本篇文章主要讲述如何通过Cloudera Manager...

4619
来自专栏Android开发与分享

【Android】升级Gradle版本(无梯子)

3598
来自专栏Laoqi's Linux运维专列

KVM部署篇

2734
来自专栏乐沙弥的世界

基于Innobackupex的增备及恢复

    MySQL的热备(物理备份)可以采取全备加增量备份的方式来减轻数据库I/O压力及系统资源的占用。增量备份主要是以全备或增量备份为基础,备份那些变更过的页...

552
来自专栏性能与架构

Phoenix - Hbase与SQL

Phoenix是什么 简单来说,Phoenix 是一个可以让我们通过SQL的方式操作HBase数据库的框架。 HBase是一个NoSQL数据库,shell客户端...

3326
来自专栏编程直播室

Centos 7 Outbound DoS攻击系统安全配置安装nginx安装Mysql查看监听端口安装shadowsocks添加防火墙查找IP地址安装PHP安装 phpMyAdmin安装java安装T

21110
来自专栏散尽浮华

kvm虚拟化管理平台WebVirtMgr部署-完整记录(3)

继下面三篇文章完成了kvm虚拟化管理平台webvirtmgr环境的部署安装: 一般情况下,虚拟机(下面称vm)跟宿主机通过网桥方式进行通信,只要宿主机能联网...

1839
来自专栏哈雷彗星撞地球

iOS下JS与OC互相调用(七)--Cordova 基础

在介绍Cordova之前,必须先提一下PhoneGap。PhoneGap 是Nitobi软件公司2008年推出的一个框架,旨在弥补web 和iOS 之间的不足,...

732
来自专栏cs

加密软件pgp-使用教程

想要安装的小伙伴,可以参考这一篇文章。 pgp--安装教程 ---- a 创建和设置初始用户。 1.0 打开pgpkeys,在菜单栏单击keys,选择 Ne...

3708

扫码关注云+社区