mysql定时任务的实现

mysql定时任务的实现

https://blog.csdn.net/erdongritian/article/details/53158617

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

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

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

      查看event是否启用:

[sql]  view plain  copy
  1. SELECT @@event_scheduler;  
  2. SHOW VARIABLES LIKE 'event%';  

      开启定时任务:

[sql]  view plain  copy
  1. set GLOBAL event_scheduler = 1;  
  2. SET GLOBAL event_scheduler = ON;  

建立定时任务:

[sql]  view plain  copy
  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  

     建立存储过程:

[sql]  view plain  copy
  1. DROP PROCEDURE IF EXISTS PRO_ALARM;  
  2. CREATE PROCEDURE PRO_ALARM()  
  3.   BEGIN  
  4.     DECLARE userId VARCHAR(32);  
  5.   
  6.     #这个用于处理游标到达最后一行的情况  
  7.     DECLARE s INT DEFAULT 0;  
  8.   
  9.     #声明游标cursor_name(cursor_name是个多行结果集)  
  10.     DECLARE cursor_data CURSOR FOR  
  11.       SELECT tmp.USER_ID  
  12.       FROM (  
  13.              SELECT  
  14.                e.USER_ID,  
  15.                MAX(e.TIME_GMT) TIME_GMT  
  16.              FROM EVENTS e  
  17.              GROUP BY e.USER_ID  
  18.              HAVING MAX(e.TIME_GMT) < UNIX_TIMESTAMP() - 60 * 30  
  19.                     AND MAX(e.TIME_GMT) > UNIX_TIMESTAMP() - 60 * 60 * 24) tmp  
  20.         INNER JOIN EVENTS t ON tmp.USER_ID = t.USER_ID  
  21.                                      AND tmp.TIME_GMT = t.TIME_GMT  
  22.       WHERE TYPE_ID != '34001';  
  23.   
  24.     #设置一个终止标记  
  25.     DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET s = 1;  
  26.   
  27.     OPEN cursor_data;  
  28.   
  29.     #获取游标当前指针的记录,读取一行数据并传给变量a,b  
  30.     FETCH cursor_data  
  31.     INTO userId;  
  32.   
  33.     #开始循环,判断是否游标已经到达了最后作为循环条件  
  34.     WHILE s <> 1 DO  
  35.       INSERT INTO EVENTS_NOTIFICATION VALUES (NULL, SYSDATE(), UNIX_TIMESTAMP(SYSDATE()),  
  36.                                                     UNIX_TIMESTAMP(SYSDATE()), '00000', userId, '1''0');  
  37.       #读取下一行的数据  
  38.       FETCH cursor_data  
  39.       INTO userId;  
  40.     END WHILE;  
  41.     #关闭游标  
  42.     CLOSE cursor_data;  
  43.   
  44.   END;  

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

[plain]  view plain  copy
  1. [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


猜你喜欢

转载自blog.csdn.net/u013344884/article/details/80104619