您好,欢迎访问一九零五行业门户网

mysql 定时执行存储过程_MySQL

查看event是否开启: show variables like '%sche%'; 
将事件计划开启: set global event_scheduler=1; 
关闭事件任务: alter event e_test on completion preserve disable; 
开户事件任务: alter event e_test on completion preserve enable; 
简单实例. 
创建表 create table test(endtime datetime); 
创建存储过程test 
create procedure test () 
begin 
update examinfo set endtime = now() where id = 14; 
end; 
创建event e_test 
create event if not exists e_test 
on schedule every 30 second 
on completion preserve 
do call test(); 
每隔30秒将执行存储过程test,将当前时间更新到examinfo表中id=14的记录的endtime字段中去 
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秒钟后,再执行查询看看: 
copyright dedecms
mysql> select * from aaa; 
+———————+ 
| timeline | 
+———————+ 
| 2007-07-18 20:44:26 | 
| 2007-07-18 20:44:27 | 
| 2007-07-18 20:44:28 | 
+———————+ 
2) 5天后清空test表: 
create event e_test 
on schedule at current_timestamp + interval 5 day 
do truncate table test.aaa; 
3) 2007年7月20日12点整清空test表: 
create event e_test 
on schedule at timestamp '2007-07-20 12:00:00' 
do truncate table test.aaa; 
4) 每天定时清空test表: 
create event e_test 
on schedule every 1 day 
do truncate table test.aaa; 
5) 5天后开启每天定时清空test表: 
create event e_test 
on schedule every 1 day 
starts current_timestamp + interval 5 day 
do truncate table test.aaa; 
6) 每天定时清空test表,5天后停止执行: 
create event e_test 
on schedule every 1 day 
ends current_timestamp + interval 5 day 
do truncate table test.aaa; 
7) 5天后开启每天定时清空test表,一个月后停止执行: 本文来自织梦 
create event e_test 
on schedule every 1 day 
starts current_timestamp + interval 5 day 
ends current_timestamp + interval 1 month 
do truncate table test.aaa; 
[on completion [not] preserve]可以设置这个事件是执行一次还是持久执行,默认为not preserve。 
8) 每天定时清空test表(只执行一次,任务完成后就终止该事件): 
create event e_test 
on schedule every 1 day 
on completion not preserve 
do truncate table test.aaa; 
[enable | disable]可是设置该事件创建后状态是否开启或关闭,默认为enable。 
[comment ‘comment’]可以给该事件加上注释。 
三、修改事件(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; 
create event test 
on schedule at '2007-09-01 12:00:00' + interval 1 day 
on completion not preserve 
do insert into yyy values('hhh','uuu'); 
解释:从2007-09-01开始,每天对表yyy在12:00:00进行一个插入操作。而且只执行一次(on completion not preserve ) 
我的计划任务为: 
create event sysplan 
on schedule at '2014-05-22 23:00:00' + interval 1 day 
on completion not preserve 
do truncate table bjproj.ae_tmp; 
三、通过设定全局变量event_scheduler 的值即可动态的控制事件调度器是否启用。 
查看是否event_scheduler开启mysql> show variables like '%event%'; 
设置开启mysql> set global event_scheduler=on; 
四、例子: 
每分钟插入一条日志:delimiter //create event `user_log_event` on schedule every 1 minute starts '2014-05-27 00:00:00' on completion not preserve enable do begin insert into log set addtime=now();end//
织梦好,好织梦
其它类似信息

推荐信息