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


      最近做了一个招聘的项目,在项目中有一个定时下线的需求。在做之前我一直在考虑到底使用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 服务的定时任务写上。

  • 相关阅读:
    SourceTree使用教程(六)--回滚版本到某次提交
    SourceTree使用教程(四)---冲突解决
    Git 分支合并后回退的几种情况分析
    HTTP认证之基本认证——Basic(二) _
    C#3.0中自动属性和对象初始化器
    C# 3.0新特征之创建和初始化集合对象
    SQL 用多个条件进行排序;以及根据一个条件的多个值,进行排序
    如何修改 .NET Core Kestrel 下的端口
    存储过程
    mysql临时表用法分析【查询结果可存在临时表中】
  • 原文地址:https://www.cnblogs.com/Can-daydayup/p/9781439.html
Copyright © 2020-2023  润新知