Mysql Event 调度历史记录

Mysql Event 调度历史记录

目前的mysql版本没有Event执行历史信息,为方便查看Event是否正常执行以及执行结果,可以通过以下两个步骤来实现:

 

一.创建作业执行Event历史记录表

[sql]  view plain  copy
  1. CREATE TABLE `mysql`.`t_event_history` (  
  2.   `dbname` VARCHAR(128) NOT NULL DEFAULT '',  
  3.   `eventname` VARCHAR(128) NOT NULL DEFAULT '',  
  4.   `starttime` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00',  
  5.   `endtime` DATETIME DEFAULT NULL,  
  6.   `issuccess` INT(11) DEFAULT NULL,  
  7.   `duration` INT(11) DEFAULT NULL,  
  8.   `errormessage` VARCHAR(512) DEFAULT NULL,  
  9.   `randno` INT(11) DEFAULT NULL,  
  10.   PRIMARY KEY (`dbname`,`eventname`,`starttime`),  
  11.   KEY `ix_endtime` (`endtime`),  
  12.   KEY `ix_starttime_randno` (`starttime`,`randno`)  
  13. ) ENGINE=INNODB DEFAULT CHARSET=utf8;  

 

二.根据以下建模板创建作业

#请注意根据实际情况修改相关信息

[sql]  view plain  copy
  1. DELIMITER $$  
  2. CREATE DEFINER=`root`@`localhost` EVENT `e_test` ON SCHEDULE   
  3. #修改以下调度信息  
  4. EVERY 1 DAY STARTS '2014-01-03 01:00:00' ON COMPLETION PRESERVE ENABLE DO   
  5. BEGIN  
  6.     DECLARE r_code CHAR(5) DEFAULT '00000';  
  7.     DECLARE r_msg TEXT;  
  8.     DECLARE v_error INTEGER;  
  9.     DECLARE v_starttime DATETIME DEFAULT NOW();  
  10.     DECLARE v_randno INTEGER DEFAULT FLOOR(RAND()*100001);  
  11.       
  12.     INSERT INTO mysql.t_event_history (dbname,eventname,starttime,randno)   
  13.     #修改下面的作业名(该作业的名称)  
  14.     VALUES(DATABASE(),'e_test', v_starttime,v_randno);    
  15.       
  16.     BEGIN  
  17.         #异常处理段  
  18.         DECLARE CONTINUE HANDLER FOR SQLEXCEPTION    
  19.         BEGIN  
  20.             SET  v_error = 1;  
  21.             GET DIAGNOSTICS CONDITION 1 r_code = RETURNED_SQLSTATE , r_msg = MESSAGE_TEXT;  
  22.         END;  
  23.           
  24.         #此处为实际调用的用户程序过程  
  25.         CALL test.usp_test1();  
  26.     END;  
  27.       
  28.     UPDATE mysql.t_event_history SET endtime=NOW(),issuccess=ISNULL(v_error),duration=TIMESTAMPDIFF(SECOND,starttime,NOW()), errormessage=CONCAT('error=',r_code,', message=',r_msg),randno=NULL WHERE starttime=v_starttime AND randno=v_randno;  
  29.       
  30. END$$  
  31. DELIMITER ;  

通过查询mysql.t_event_history表,我们就知道event何时执行,执行是否成功,执行时长,出错时的错误信息,为管理我们日常调度计划提供很大方便。


目前的mysql版本没有Event执行历史信息,为方便查看Event是否正常执行以及执行结果,可以通过以下两个步骤来实现:

 

一.创建作业执行Event历史记录表

[sql]  view plain  copy
  1. CREATE TABLE `mysql`.`t_event_history` (  
  2.   `dbname` VARCHAR(128) NOT NULL DEFAULT '',  
  3.   `eventname` VARCHAR(128) NOT NULL DEFAULT '',  
  4.   `starttime` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00',  
  5.   `endtime` DATETIME DEFAULT NULL,  
  6.   `issuccess` INT(11) DEFAULT NULL,  
  7.   `duration` INT(11) DEFAULT NULL,  
  8.   `errormessage` VARCHAR(512) DEFAULT NULL,  
  9.   `randno` INT(11) DEFAULT NULL,  
  10.   PRIMARY KEY (`dbname`,`eventname`,`starttime`),  
  11.   KEY `ix_endtime` (`endtime`),  
  12.   KEY `ix_starttime_randno` (`starttime`,`randno`)  
  13. ) ENGINE=INNODB DEFAULT CHARSET=utf8;  

 

二.根据以下建模板创建作业

#请注意根据实际情况修改相关信息

[sql]  view plain  copy
  1. DELIMITER $$  
  2. CREATE DEFINER=`root`@`localhost` EVENT `e_test` ON SCHEDULE   
  3. #修改以下调度信息  
  4. EVERY 1 DAY STARTS '2014-01-03 01:00:00' ON COMPLETION PRESERVE ENABLE DO   
  5. BEGIN  
  6.     DECLARE r_code CHAR(5) DEFAULT '00000';  
  7.     DECLARE r_msg TEXT;  
  8.     DECLARE v_error INTEGER;  
  9.     DECLARE v_starttime DATETIME DEFAULT NOW();  
  10.     DECLARE v_randno INTEGER DEFAULT FLOOR(RAND()*100001);  
  11.       
  12.     INSERT INTO mysql.t_event_history (dbname,eventname,starttime,randno)   
  13.     #修改下面的作业名(该作业的名称)  
  14.     VALUES(DATABASE(),'e_test', v_starttime,v_randno);    
  15.       
  16.     BEGIN  
  17.         #异常处理段  
  18.         DECLARE CONTINUE HANDLER FOR SQLEXCEPTION    
  19.         BEGIN  
  20.             SET  v_error = 1;  
  21.             GET DIAGNOSTICS CONDITION 1 r_code = RETURNED_SQLSTATE , r_msg = MESSAGE_TEXT;  
  22.         END;  
  23.           
  24.         #此处为实际调用的用户程序过程  
  25.         CALL test.usp_test1();  
  26.     END;  
  27.       
  28.     UPDATE mysql.t_event_history SET endtime=NOW(),issuccess=ISNULL(v_error),duration=TIMESTAMPDIFF(SECOND,starttime,NOW()), errormessage=CONCAT('error=',r_code,', message=',r_msg),randno=NULL WHERE starttime=v_starttime AND randno=v_randno;  
  29.       
  30. END$$  
  31. DELIMITER ;  

通过查询mysql.t_event_history表,我们就知道event何时执行,执行是否成功,执行时长,出错时的错误信息,为管理我们日常调度计划提供很大方便。


猜你喜欢

转载自blog.csdn.net/wrh_csdn/article/details/79712778
今日推荐