使用MySQLl事件定时执行岗位七天下线任务
2023-02-18 16:31:46 时间
最近做了一个招聘的项目,在项目中有一个定时下线的需求。在做之前我一直在考虑到底使用window 服务,还是使用调度,最终我选择使用mysql定时事件,因为这样简单方便。
思路:首先创建一个存储过程,通过游标遍历更新对应的岗位状态,让后在创建定时事件,废话不多说直接上代码
首先创建存储过程:
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
创建数据库事件:
#查看数据库事件是否开启 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 服务的定时任务写上。
相关文章
- php使用redis实现消息队列实例
- Kubernetes命令行工具 - kubectl用法总结
- 一键安装高可用Kubernetes集群的工具,支持本地环境和云环境
- 云原生钻石课程 | 第7课:Kubernetes 网络架构原理深度剖析(下)
- 虚实相生,构建数智生活|HMS Core. Sparkle应用创新分论坛报名启动
- 报名启动丨HMS Core. Sparkle应用创新论坛
- 中文主播也能海外带货!同声传译助直播类应用开拓海外市场
- HMS Core 机器学习服务打造同传翻译新“声”态,AI让国际交流更顺畅
- 无密码身份验证如何保障用户隐私安全?
- 【FAQ】华为帐号服务报错 907135701的常见原因总结和解决方法
- 华为HMS Core携手超图为三维GIS注入新动能
- HMS Core音频编辑服务3D音频技术,助力打造沉浸式听觉盛宴
- 华为帐号多端协同,打造美好互联生活
- HMS Core打造影音娱乐行业解决方案,助推视听新浪潮
- 运动App如何实现端侧后台保活,让运动记录更完整?
- 品质影音体验,畅享娱乐生活丨HMS Core.Sparkle影音娱乐创新线上沙龙报名启动
- HMS Core机器学习服务实现同声传译,支持中英文互译和多种音色语音播报
- 华为机器学习服务语音识别功能,让应用绘“声”绘色
- 影音娱乐应用开发,这些关键词请查收
- 在线文本实体抽取能力,助力应用解析海量文本数据