开发者社区> 杰克.陈> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

Mysql编写定时任务事件

简介: 原文:Mysql编写定时任务事件 场景:   例如:某系统,用户每天只能拥有一次的抽奖机会,抽过后当天就不可再抽,但是过了24:00点后用户就重新拥有一次抽奖机会。像这种需要数据库定时对某个字段进行更新操作的任务,完全可以通过数据库本身的事件机制进行操作,而服务器端也不需要用额外的代码进行这种监控定时的操作。
+关注继续查看
原文:Mysql编写定时任务事件

场景:

  例如:某系统,用户每天只能拥有一次的抽奖机会,抽过后当天就不可再抽,但是过了24:00点后用户就重新拥有一次抽奖机会。像这种需要数据库定时对某个字段进行更新操作的任务,完全可以通过数据库本身的事件机制进行操作,而服务器端也不需要用额外的代码进行这种监控定时的操作。

Mysql:

  本文讨论的是Mysql数据库,Event Scheduler事件调度器应该是在Mysql5.1引入的,所以使用定时任务调度时,请注意查看你的Mysql版本。

创建事件调度的语法:

/*创建事件event_name*/
DELIMITER $$

CREATE event IF NOT EXISTS event_name

ON SCHEDULE 任务条件 

ON COMPLETION PRESERVE

DO SQL操作

DELIMITER ;

实例情景:每半个小时更新统计字段count为0,

/*创建定时定时更新count字段事件*/
DELIMITER $$

CREATE event IF NOT EXISTS update_count

ON SCHEDULE EVERY 30 MINUTE 

/*MYSQL注意时区设置,默认非中国时区*/
STARTS TIMESTAMP '2009-12-18 02:58:00' ON COMPLETION PRESERVE DO update tb_count set count=0 $$ DELIMITER ;

如上,创建了一个名叫update_count的事件,执行条件则为每30分钟执行一次,(EVERY 30 MINUTE),执行Sql为(update tb_count set count=0), 当然你可能会按天执行,所以你也可以写(EVERY 1 DAY),

如果执行的任务Sql复杂,我们可以写触发器,直接看示例代码:

DELIMITER $$

DROP PROCEDURE IF EXISTS update_count$$

CREATE PROCEDURE update_count()

BEGIN
    UPDATE tb_count SET count=0;
END$$

DELIMITER ;

以上为创建一个存储过程update_count,执行对tb_count中count字段的更新。任务中代码中do字段后则改为(call update_count() $$)。当然你可能会更复杂的需求。

添加完event后,还需要查看event_scheduler是否开启,否则添加的event不会执行,移步下面的代码:

/*查看event是否开启*/
SHOW VARIABLES LIKE '%sche%';
/*开启event*/
SET GLOBAL event_scheduler=1;

查看和关闭你所添加的event:

 

/*关闭 event */
ALTER event update_count ON COMPLETION PRESERVE DISABLE;

/*启用 event */
ALTER event update_count ON COMPLETION PRESERVE ENABLE;

 更多MySql语法可查看:http://dev.mysql.com/doc/refman/5.1/zh/sql-syntax.html

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
mysql设置定时任务
mysql设置定时任务http://www.bieryun.com/3083.html 今天遇到了个需要每天定时执行的任务,在mysql数据库里面提供了这样的功能,正好整理下分享出来。 1.首先检查是否开启了定时任务 1 2 3 4 5 6 查看event是否开启 : SHOW V.
1283 0
mysql设置定时任务
mysql设置定时任务 今天遇到了个需要每天定时执行的任务,在mysql数据库里面提供了这样的功能,正好整理下分享出来。 1.首先检查是否开启了定时任务 1 2 3 4 5 6 查看event是否开启 : SHOW VARIABLES LIKE '%event_sche%'; .
1211 0
mysql事务
版权声明:欢迎转载,请注明沉默王二原创。 https://blog.csdn.net/qing_gee/article/details/42551179 项目中使用的是mysql数据库,有幸看到《高性能mysql》一书,并且参考其对事务的介绍,结合实际开发对事务进行了测试,主要关注点在事务的隔离级别、innodb_flush_log_at_trx_commit、autocommit参数对mysql性能的影响。
695 0
+关注
杰克.陈
一个安静的程序猿~
10424
文章
2
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载