使用MySQL计划任务

转载 2013年12月02日 14:51:55

【转载】使用MySQL计划任务


原先,LAMP的程序员为了完成一些周期性的数据库操作任务,总是不得不借助于操作系统的帮助,比如Windows的计划任务,或者Linux的contab。MySQL5.1终于新增了Event Scheduler功能,可以直接在后台实现一下定时性的作业。但不知道什么原因,在英文版的参考手册中,位于触发器和视图之间的第20章Event Scheduler,在中文版中被删减掉了,手册的其他部分也没有丝毫提到它,好像它根本就不存在一样,所以它的知名度不是很高。有兴趣的读者可以参考http://dev.mysql.com/doc/refman/5.1/en/events.html获得比较完整的帮助。 

1.1 开启 
     MySQL的Event Scheduler是根据预先安排的计划进行数据库操作的数据库对象,可以看作是一种“时间触发器”。Event实际上是被一个特殊的event scheduler线程执行的,假如它正在运行的话,可以通过SHOW PROCESSLIST命令看到它。全局变量event_scheduler用来设定是否服务器端运行执行计划任务,该变量有如下三种值: 
      OFF:计划任务处于停止状态,event scheduler线程没有运行。是event_scheduler的默认值; 
      ON:计划任务处于运行状态,event scheduler线程启动,并执行所有的计划任务; 
      DISABLED:该值将致使计划任务不可运行 
     你可以使用下列的任意一句开启计划任务: 
           SET GLOBAL event_scheduler = ON; 
           SET @@global.event_scheduler = ON; 
           SET GLOBAL event_scheduler = 1; 
           SET @@global.event_scheduler = 1; 

1.2 创建 
     Event Scheduler作为一种数据库对象,其增删改的DDL语句与其他对象非常相似,无非CREATE、ALTER、DROP等,创建的基本语法是: 
          CREATE EVENT        (1) 
          [IF NOT EXISTS]        (2) 
          event_name         (3) 
          ON SCHEDULE schedule      (4) 
          [ON COMPLETION [NOT] PRESERVE]   (5) 
          [ENABLE | DISABLE]       (6) 
          [COMMENT 'comment']       (7) 
          DO sql_statement        (8) 
     逐条介绍: 
     (1) 创建Event嘛,这俩关键字当然不能少了 
     (2) 如果不存在同名的数据库对象才创建 
     (3) 计划任务的名字。作为数据库对象,都有一个本库内唯一的名字做标识 
     (4) 计划任务的计划,重点就在这儿。有两个关键字来设定任务的执行计划:AT和EVERY: 
          AT指定的是一个一次性计划,后面跟着一个时间戳,后续的sql语句将在指定的时间被执行一次; 
          EVERY指定的是一个周期性计划,在该子句中可以指定从某时间点到某时间点期间,每隔某周期就执行一次该任务。 
     (5) 任务整个执行完毕后,该计划任务对象是否还在数据库中保留。默认不保留 
     (6) 有效或失效。默认有效 
     (7) 真正要执行的语句 

1.3 实例 
      首先是一个一次性计划任务的例子,该任务在指定的2008-02-06 23:59:00这个时间点,向messages表中插入一条记录: 
          CREATE EVENT e_totals 
          ON SCHEDULE AT '2006-02-10 23:59:00' 
          DO 
          INSERT INTO messages VALUES (null, 'admin', '过年了!', '祝大家鼠年发大财!!!', '127.0.0.1',NOW()); 
      下面是一个周期性计划任务的例子,该任务在2008-02-06 23:59:00开始的一年内,每隔1小时就删除掉messages表的早先的10条记录: 
          CREATE EVENT e_hourly 
          ON SCHEDULE 
          EVERY 1 HOUR STARTS '2007-02-10 23:59:00' ENDS '2008-02-10 23:59:00' 
          DO 
          DELETE FROM messages limit 10; 

     计划任务属于数据库服务器端的对象,创建好后,只要开启了event_scheduler,就可以自动触发执行了,不用在前台进行任何干预。当然一定要记住,只有MySQL5.1以上版本才支持该对象。 

数据库_MySQL_MySQL的计划任务(相当于定时器的功能)

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

用Navicat 计划任务备份mysql数据库

需要对mysql数据库进行每日备份
  • zhouyingge1104
  • zhouyingge1104
  • 2014年05月29日 11:24
  • 12265

MySQL定时执行脚本(计划任务)命令实例

查看event是否开启        复制代码 代码如下:  show variables like '%sche%';  将事件计划开启        ...
  • sinat_31092021
  • sinat_31092021
  • 2016年08月08日 20:28
  • 937

MySQL 事件(event)计划任务

准备、开启mysql的event 修改/etc/my.cnf加入如下配置: event_scheduler = 1 #更多方法请查看开启mysql event的几种方法 一、新建数据库 mysql>...
  • hjq198988
  • hjq198988
  • 2016年01月30日 21:28
  • 1489

第二步 使用mysqldump 和 crontab定时任务定时备份数据库

(以下所有操作都是在root权限下!!!) 先来说说mysqldump这个工具  这个工具是mysql提供的备份还原mysql数据库的工具先来讲讲备份  mysqldump -uroot -h1...
  • work_msh
  • work_msh
  • 2013年01月06日 17:05
  • 1260

Mysql计划任务自动定时备份数据库方法-for windows

数据库名称为:952game数据库备份目的地:d:\db_bak\ (你想把数据库备份到哪个盘的路径)我想备到D盘的db-bak目录下面============================新建db...
  • xmlife
  • xmlife
  • 2016年07月29日 20:11
  • 1864

shell处理mysql增、删、改、查

shell处理mysql增、删、改、查 参考博客第五种方法:http://blog.csdn.net/u011630575/article/details/50986835 引言 ...
  • u011630575
  • u011630575
  • 2016年08月07日 22:19
  • 1401

Mysql定时执行任务实现方法

在开发过程中遇到过排行榜的问题,曾经想用 mysql 的 event 计划任务去做,每天让数据库定期更新数据,程序只需要拉更新后的数据即可。但是,这有几个问题: 1、如果数据量很大的话,数据库的...
  • zlp5201
  • zlp5201
  • 2014年07月31日 00:57
  • 33362

Navicat for MySQL 设置定时任务(事件)

进来开发项目时遇到一个问题,就是每天定时修改数据表中签到的字段。现在我就来记录一下用Navicat for MySQL 来实现定时任务。 1、启动Navicat for MySQL,新建数据库连接,打...
  • baochao95
  • baochao95
  • 2015年05月24日 12:53
  • 13460

mysql计划任务

今天有个网友说数据库里一个用户删除了,还是会生成,应该被入侵了,首先想到的做法就是写了linux的计划任务,但是一想不对啊,如果root密码改了呢,连不上数据库怎么写sql,然后一百度发现了mysql...
  • bwlab
  • bwlab
  • 2016年07月04日 11:27
  • 7010
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:使用MySQL计划任务
举报原因:
原因补充:

(最多只允许输入30个字)