MySql 定时任务的使用

by:授客 QQ1033553122

简介

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

操作:

1,开启event_scheduler计划。

法1:

新建查询,执行语句:set GLOBAL event_scheduler = 1;

法2:编辑my.cnf,进入mysql安装目录,找到my.cnf配置文件,在文件中添加event_scheduler = 1

示例(linux下)

builder:~# find / -name my.cnf

/mnt/mysql/my.cnf

builder:~# cd /mnt/mysql/

builder:/mnt/mysql# vi my.cnf

……

  

2,要查看当前是否已开启事件调度器

执行如下SQL:

法1,sql查询器中:show variables like 'event_scheduler';

法2,sql查询器中:select @@event_scheduler;

法3,show
processlist; 


3,
创建事件(create
event)

语法:  

CREATE
EVENT [IFNOT EXISTS] event_name

  
ONSCHEDULE schedule

  
[ONCOMPLETION [NOT] PRESERVE]

  
[ENABLE | DISABLE]

  
[COMMENT 'comment']

  
DO sql_statement;

注:

schedule:

  
AT TIMESTAMP [+ INTERVAL INTERVAL]

  
| EVERY INTERVAL [STARTS TIMESTAMP] [ENDS
TIMESTAMP]
  

INTERVAL:

quantity {YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE |

WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE

| DAY_SECOND | HOUR_MINUTE | OUR_SECOND |
MINUTE_SECOND} 

[ENABLE
| DISABLE]:设置该事件创建后状态是否开启或关闭,默认为ENABLE。

[COMMENT
‘comment’]:可以给该事件加上注释。


4
,修改事件(ALTER
EVENT)

语法:

ALTER
EVENT event_name

  
[ONSCHEDULE schedule]

  
[RENAME TOnew_event_name]

  
[ONCOMPLETION [NOT] PRESERVE]

  
[COMMENT 'comment']

  
[ENABLE | DISABLE]

  
[DO sql_statement]


5
,删除事件(DROP
EVENT)

语法:

DROP
EVENT [IF EXISTS] event_name


6
,举例


#
查看数据库版本[5.1.6]

select
version();


#
开启evenet_sheduler进程

set
GLOBAL event_scheduler = 1;


#
查看当前是否已开启事件调度器

#法1

show
variables like 'event_scheduler';

#法2

select
@@event_scheduler;

#法3

show
processlist;


#
查看当前数据库中所有事件

show
events;


#
查看所有数据库中所有事件

#法1

select
* from mysql.event;

#法2

select
* from information_schema.events


#
创建定时任务

#1.测试环境搭建

#1.1查看存在那些数据库

show
databases;

#1.2进入数据库

use
test;

#1.3查看表

show
tables;

#1.4创建测试表student

create
table student

(

num integer,

name varchar(6),

addr varchar(10),

comment varchar(15)

)

#1.5显示表结构

desc
student;

#1.6插入数据

insert
into student values(1,'lili','noaddr','nocomment');

insert
into student values(2,'xiaoli','noaddr','nocomment');

insert
into student select * from student;


#2
创建定时清理任务

#2.1每3秒清理一次表

create
event if not exists e_delete

on
schedule every 3 second

do
truncate table test.student;

#查看效果

select
* from test.student;

#2.2每天插入1条数据

create
event e_insert

on
schedule every 1 day

do
insert into test.student
values(3,'test','noaddr','nocoment');

#2.3五天后清空表

create
event e_truncate

on
schedule at current_timestamp + interval 5 day

do
truncate table test.student;

#2012年11月12日12点12分12秒清空表

create
event e_truncate

on
schedule at timestamp '2012-11-12 12:12:12'

do
truncate table test.student;

#每1天执行一次清空表

create
event e_truncate

on
schedule every 1 day

do
truncate table test.student;

#五天后开启每天执行一次清空表

create
event e_truncate

on
schedule every 1 day

starts
current_timestamp + interval 5 day

do
truncate table test.student;

#五天后停止每天执行一次清空表

create
event e_truncate

on
schedule every 1 day

ends
current_timestamp + interval 5 day

do
truncate table test.student;

#五天后开启每天执行一次清空表,1个月后停止

create
event e_truncate

on
schedule every 1 day

starts
current_timestamp + interval 5 day

ends
current_timestamp + interval 1 month

do
truncate table test.student;

#每天执行一次清空表,执行完后终止事件,以后都不执行了

create
event e_truncate

on
schedule every 1 day

on
completion not preserve

do
truncate table test.student;


#3
临时关闭事件

use
test;

alter
event e_delete disable;

#注意:禁用定时功能后,当你重新启动mysql服务时,该定时功能可能被删除。查看是否被删除语句如下

show
events;


#4
开启事件

use
testdb;

alter
event e_delete enable;


#5
修改事件,如改为每5天清理一次

alter
event e_delete

on
schedule every 5 day

do
truncate table table_name;


#6
永久删除事件

use
testdb;

drop
event if exists e_delete;

MySql 定时任务的使用的更多相关文章

  1. mysql定时任务简单例子

    mysql定时任务简单例子 ? 1 2 3 4 5 6 7 8 9     如果要每30秒执行以下语句:   [sql] update userinfo set endtime = now() WHE ...

  2. MySql 利用crontab实现MySql定时任务

    MySql 利用crontab实现MySql定时任务 by:授客 QQ:1033553122 适用平台 任意myslq版本数据库 操作方法 登陆到数据库系统所在的linxu系统 第一步:新建名为cro ...

  3. mysql 定时任务job

    mysql 定时任务job 1.通过show EVENTS显示当前定义的事件 2.检查event_scheduler状态:SHOW VARIABLES LIKE 'event_scheduler' 3 ...

  4. mysql 定时任务和存储过程

    mysql 定时任务和存储过程 最近在做日志系统,中间用到了 mysql, 其中有一个要求: 把数据库中 7天之后的日志清除了.看到 mysql 也支持 定时任务.于是就用 mysql 来做了.下面就 ...

  5. mysql定时任务(数据库管理工具and 纯命令行)

    1.工具:Navicat 2.通过下列语句l爱查询event是否开启 打开Navicat命令列界面(点击工具可以看到或按F6) 输入下面命令 show variables like '%sche%'; ...

  6. MySQL定时任务event,储存过程(定时删除指定时间前90天指定表的数据)

    MySQL定时任务event,储存过程(定时删除指定时间前90天指定表的数据) 分类: MySql5.x2014-06-23 15:16 1266人阅读 评论(0) 收藏 举报 mysql数据库 &l ...

  7. mysql 定时任务

    mysql 5.1以上支持定时任务. SHOW VARIABLES LIKE 'event_scheduler';   检查是否已开启该功能 开启计划任务功能: SET GLOBAL event_sc ...

  8. mysql 定时任务的使用

    mysql5.1.6增加了一个事件调度器(Event Scheduler),可以做定时任务(定时删除记录,定时数据统计),取代之前系统的计划任务.mysql事件调度器可以精确到每秒执行一个任务. 事件 ...

  9. Navicat设定mysql定时任务步骤示例

    怎样在Navicat中设置,是数据库按照记录中的日期更新状态字段 其实这个很常用,比如你网站里的某条记录的日期——比如说数据库中某条活动记录的审核日期字段已经过期,亦即当前时间已经超过审核日期,那么定 ...

随机推荐

  1. KVM的VPS主机在Centos6.x下修改系统时间

    显示系统时间 # date "+%Y-%m-%d %H:%M:%S" 修改系统时区 # cp /usr/share/zoneinfo/Asia/Shanghai /etc/loca ...

  2. 打印页面时a标签不显示URL的方法

    以前写博客啊,总想写一篇大作,然后希望能挂到博客园首页,隔一会儿看看阅读量有多少.其实哪有那么多大作,大部分时间都是解决了一个小问题,然后需要记录一下.比如下面这篇. 今天遇到一个需求是,打印网页时, ...

  3. 手把手教你整合最优雅SSM框架

    我们看招聘信息的时候,经常会看到这一点,需要具备 SSM 框架的技能, SpringMVC 可以完全替代 Struts,配合注解的方式,编程非常快捷,而且通过 restful 风格定义 url,让地址 ...

  4. Spring总结 4.AOP之为对象添加新功能

    Spring除了提供增强原有功能的方法外,还提供了为一个对象引入新功能的方法.如下: package cn.powerfully.service; public interface IService ...

  5. redis学习(二) redis数据结构介绍以及常用命令

    redis数据结构介绍 我们已经知道redis是一个基于key-value数据存储的数据结构数据库,这里的key指的是string类型,而对应的value则可以是多样的数据结构.其中包括下面五种类型: ...

  6. 复刻smartbits的国产网络测试工具minismb-如何测试路由器

    复刻smartbits的国产网络性能测试工具minismb,是一款专门用于测试智能路由器,网络交换机的性能和稳定性的软硬件相结合的工具.可以通过此工具测试任何ip网络设备的端口吞吐率,带宽,并发连接数 ...

  7. cool--music

    1.三年的赌注 2.非酋 3.Swan Song 4.Better Than A Hallelujah

  8. MVC应用程序,动态创建单选列表(RadioButtonList)

    单选列表是多个选项,让用户选择一个.MVC应用程序开发中,少之不了.下面就来练习之个小功能. 这个练习,Insus.NET想实现一个日期显示的格式.在MVC中,得需从model开始创建: 再创建一个E ...

  9. Nginx初探

    nginx是一款轻量级的web服务器.反向代理服务器和电子邮件服务器,占有内存少,并发能力强. 本文将简单介绍如何安装.启动nginx,部署web项目,应用反向代理. 一.安装 可参考https:// ...

  10. 【公众号转载】超详细 Nginx 极简教程,傻瓜一看也会!

    什么是Nginx? Nginx (engine x) 是一款轻量级的Web 服务器 .反向代理服务器及电子邮件(IMAP/POP3)代理服务器. 什么是反向代理? 反向代理(Reverse Proxy ...