码迷,mobileinhere.cn
首页 > 数据库 > 详细

mysql计划任务每天定时执行

时间:2015-09-14 20:54:29      阅读:24955      评论:0      收藏:0      [点我收藏+]

标签:

代码例子:
create event `course_listener` on schedule every
1 day starts 2012-07-18 00:00:00 on completion preserve enable do update `om_courselist` set `status`=6 where `status`=5 and `closetime`<current_timestamp();

 

可以用navicat创建事件,更快捷:

navicat创建和设计mysql事件

1.开启定时器 0:off 1:on

 set global event_scheduler = 1;

2.在navicat左侧选择一个数据库,单击“时间”-“创建事件”,弹出一个窗口。

技术分享

在定义选项输入sql语句,以begin开头,以end结尾。

如果是在本地运行,definer为[email protected]

3.计划任务,每隔一段时间就有固定需求的操作,如创建表,删除数据等操作。

技术分享

3-1. at 时间戳,用来完成单次的计划任务。

3-2. every 时间(单位)的数量时间单位[starts 时间戳] [ends时间戳],用来完成重复的计划任务。时间单位较多,按需选择。

在两种计划任务中,时间戳可以是任意的timestamp 和datetime 数据类型,时间戳需要大于当前时间。

最后保存就ok了

 

附上mysql事件的语法:

mysql 或 mariadb 事件语法

mysql 事件计划是在 mysql 5.1.6 添加。mysql 事件是按计划运行工作。因此,我们有时称它们为计划事件。当你创建一个事件时,你是创建一个有名的数据库对象,包含在一个或多个规律区间运行一个或多个 sql 语句,并在特定的日期时间开始及结束。从概念上,这是类似 windows 任务计划程序的概念。点击 技术分享 来打开 事件 的对象列表。

定义

定义包括一个有效的 sql 语句。这可以是一个简单的语句,如 selectinsert,或它可以是一个用 beginend 写的复合语句。复合语句可以包含声明循环和其它控制结构语句。

提示:要自定义编辑器的视图并查看更多 sql 编辑功能,请看编辑器高级功能

定义者
指定当在事件运行时检查访问权限要使用的用户帐号。默认定义者值是运行 create event 语句的的用户。(这是和 definer = current_user 相同。)如果给予一个用户值,它应该是一个 ‘user_name‘@‘host_name‘ 格式的 mysql 帐号(使用在 grant 语句相同的格式)。user_name 及 host_name 值都是必须的。

状态
你可以创建一个事件但可以用 disable 关键字保持不激活。或者,你可以用 enable 来出明确默认状态,这是激活。

on completion
正常情况下,一旦事件已过期,它将立即删除。你可以通过指定 on completion preserve 来重写此性能。使用 on completion not preserve 只是使默认非持久性的性能明确。

计划

at
at timestamp 用于一次性事件。它指定该事件只运行一次于 timestamp 的日期和时间,它必须同时包含日期和时间,或必须是一个解析为 datetime 值的表达式。使用 +interval 来创建一个事件,它发生在与当前日期和时间有关的将来某个时候。

every
在定期间隔重复的行动,你可以用一个 every 子句之后是一个 interval。(+intervalevery 不能同时使用。)

starts
every 子句还可能包含一个非必须的 starts 子句。starts 之后是一个 timestamp 值表示行动应该何时开始重复,也可以用 +interval 间隔以指定「由现在开始」的时间量。

例如:every 3 month starts current_timestamp + 1 week 的意思是「每 3 个月,从现在起一周后开始」。

ends
every 子句还可包含一个非必须的 ends 子句。ends 关键字之后是一个 timestamp 值告诉 mysql 何时停止重复事件。你也可以用 +interval 间隔与 ends 一起。

例如:every 12 hour starts current_timestamp + interval 30 minute ends current_timestamp + interval 4 week 相当于「每十二个小时,从现在起三十分钟后开始,并于现在起四个星期后结束」。

p.s. timestamp 必须在未来的 - 你不能安排一个事件发生在过去。
 

interval 区间由两部份组成,数量和时间单位*。
*year | quarter | month | day | hour | minute |
week | second | year_month | day_hour | day_minute |
day_second | hour_minute | hour_second | minute_second

 

 来源:www.navicat.com.cn/manual/online_manual/cn/navicat/win_manual/eventsmysql.html

 

mysql计划任务每天定时执行

标签:

原文地址:www.cnblogs.com/langtianya/p/4808065.html

(2)
(6)
   
举报
评论 一句话评论(0
0条  
登录后才能评论!
2014 mobileinhere.cn 版权所有 京icp备13008772号-2
华人娱乐注册