前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用MySQLl事件定时执行岗位七天下线任务

使用MySQLl事件定时执行岗位七天下线任务

作者头像
追逐时光者
发布2022-02-15 15:21:28
3370
发布2022-02-15 15:21:28
举报
文章被收录于专栏:编程进阶实战编程进阶实战

  最近做了一个招聘的项目,在项目中有一个定时下线的需求。在做之前我一直在考虑到底使用window 服务,还是使用调度,最终我选择使用mysql定时事件,因为这样简单方便。

思路:首先创建一个存储过程,通过游标遍历更新对应的岗位状态,让后在创建定时事件,废话不多说直接上代码

首先创建存储过程:

代码语言:javascript
复制
CREATE DEFINER = CURRENT_USER PROCEDURE `TimedDownLine`()
BEGIN
-- 声明变量(用于插入数据)
DECLARE PostID INT;#岗位ID
DECLARE DifferDay INT;#相差天数
DECLARE done INT DEFAULT 0;#判断是否存在信息的依据0表示存在数据

DECLARE Integral_cursor cursor for SELECT id,TIMESTAMPDIFF(DAY, ReleaseEnd, now()) AS intervalday FROM postrelease WHERE PostType=1;#查询所有在线的岗位信息(1表示在线岗位,2表示下线岗位)

 DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;#没有数据返回更改状态为1

-- 打开游标
OPEN Integral_cursor;
#开始循环
WHILE done=0 DO

#REPEAT
   #游标赋值(游标只会向下执行)
     FETCH Integral_cursor INTO PostID,DifferDay;
     IF(done=0&&DifferDay>7)
     THEN UPDATE postrelease SET PostType=2 where ID=PostID;
   end IF;
#循环结束
#UNTIL done=1 END REPEAT;
END WHILE;
SET done=1;#更改状态,表示循环结束
-- 关闭游标
END

创建数据库事件:

代码语言:javascript
复制
#查看数据库事件是否开启
SHOW VARIABLES LIKE 'event_scheduler'
show variables like '%event%';
#设置当前事件开启
SET GLOBAL event_scheduler = 1; 
#查看定时任务
select * from  mysql.event;
SELECT * FROM information_schema.events; 
#每天凌晨开始执行
select DATE_ADD(DATE_ADD(CURDATE(), INTERVAL 1 DAY), INTERVAL 13 HOUR) 
#关闭定时任务
DROP event temp_event;


#每天凌晨开始执行(创建定时事件)
CREATE EVENT IF NOT EXISTS TimeDownlines_event   
    ON SCHEDULE EVERY 1 DAY STARTS DATE_ADD(DATE_ADD(CURDATE(), INTERVAL 1 DAY), INTERVAL 0 HOUR)   
    ON COMPLETION PRESERVE ENABLE #到点开启定时任务 
    DO CALL TimedDownLine();

  这样只写对于一些业务相对于没有复杂的定时任务完全可以应对,而且开发快捷,下次有时间会把window 服务的定时任务写上。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-10-13 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档