分享

mysql定时任务的实现

 instl 2018-07-06

1,需求:每天晚上10点到早上5点,每10分钟定时执行存储过程。

2,实现方式:实现方式有两种:

       一种是比较常规的,用mysql的event定时任务,先介绍一下mysql中event定时任务的相关命令,

      查看event是否启用:

  1. SELECT @@event_scheduler;
  2. SHOW VARIABLES LIKE 'event%';

      开启定时任务:

  1. set GLOBAL event_scheduler = 1;
  2. SET GLOBAL event_scheduler = ON;

建立定时任务:

  1. DROP EVENT IF EXISTS JOB_ALARM;
  2. CREATE EVENT JOB_ALARM
  3. ON SCHEDULE EVERY 10 MINUTE
  4. DO
  5. BEGIN
  6. if(date_format(current_time(),'%H')>22 || date_format(current_time(),'%H')<5) THEN
  7. CALL PRO_ALARM();
  8. END IF;
  9. END

     建立存储过程:

  1. DROP PROCEDURE IF EXISTS PRO_ALARM;
  2. CREATE PROCEDURE PRO_ALARM()
  3. BEGIN
  4. DECLARE userId VARCHAR(32);

  5. #这个用于处理游标到达最后一行的情况
  6. DECLARE s INT DEFAULT 0;

  7. #声明游标cursor_name(cursor_name是个多行结果集)
  8. DECLARE cursor_data CURSOR FOR
  9. SELECT tmp.USER_ID
  10. FROM (
  11. SELECT
  12. e.USER_ID,
  13. MAX(e.TIME_GMT) TIME_GMT
  14. FROM EVENTS e
  15. GROUP BY e.USER_ID
  16. HAVING MAX(e.TIME_GMT) < UNIX_TIMESTAMP() - 60 * 30
  17. AND MAX(e.TIME_GMT) > UNIX_TIMESTAMP() - 60 * 60 * 24) tmp
  18. INNER JOIN EVENTS t ON tmp.USER_ID = t.USER_ID
  19. AND tmp.TIME_GMT = t.TIME_GMT
  20. WHERE TYPE_ID != '34001';

  21. #设置一个终止标记
  22. DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET s = 1;

  23. OPEN cursor_data;

  24. #获取游标当前指针的记录,读取一行数据并传给变量a,b
  25. FETCH cursor_data
  26. INTO userId;

  27. #开始循环,判断是否游标已经到达了最后作为循环条件
  28. WHILE s <> 1 DO
  29. INSERT INTO EVENTS_NOTIFICATION VALUES (NULL, SYSDATE(), UNIX_TIMESTAMP(SYSDATE()),
  30. UNIX_TIMESTAMP(SYSDATE()), '00000', userId, '1', '0');
  31. #读取下一行的数据
  32. FETCH cursor_data
  33. INTO userId;
  34. END WHILE;
  35. #关闭游标
  36. CLOSE cursor_data;

  37. END;

在配置定时器时有一些局限性,并且由于博主使用的mysql启用了skip-grant-tables,在设置event开启时,总是报错,所以想到了第二种实现方式,具体报错信息如下:

[HY000][1290] The MySQL server is running with the --event-scheduler=DISABLED or --skip-grant-tables option so it cannot execute this statement


  第二种实现方式是利用linux的定时任务,

linux定时任务基本命令:

查看定时任务:crontab -l

编辑定时任务:crontab -e

        */10 22-23,0-5 * * *   mysql -u用户名 -p密码 -e "use db_name;CALL PRO_ALARM();"

       或者把use db_name;CALL PRO_ALARM();存到sql脚本中,编辑定时任务如下:

       */10 22-23,0-5 * * *   mysql -u用户名 -p密码 < /application/Job_mysql.sql



    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多