mysqlevent建立模板(可记录执行履历)

  1. 建立履历记录表

    创新互联长期为上千家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为临清企业提供专业的成都做网站、网站制作,临清网站改版等技术服务。拥有十载丰富建站经验和众多成功案例,为您定制开发。

CREATE TABLE `MySQL`.`t_event_history` (
  `dbname` VARCHAR(128) NOT NULL DEFAULT '',
  `eventname` VARCHAR(128) NOT NULL DEFAULT '',
  `starttime` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00',
  `endtime` DATETIME DEFAULT NULL,
  `issuccess` INT(11) DEFAULT NULL,
  `duration` INT(11) DEFAULT NULL,
  `errormessage` VARCHAR(512) DEFAULT NULL,
  `randno` INT(11) DEFAULT NULL,
  PRIMARY KEY (`dbname`,`eventname`,`starttime`),
  KEY `ix_endtime` (`endtime`),
  KEY `ix_starttime_randno` (`starttime`,`randno`)
) ENGINE=INNODB DEFAULT CHARSET=utf8;

2.event 建立模板

DELIMITER $$
CREATE DEFINER=`root`@`localhost` EVENT `job_update_status` ON SCHEDULE 
#修改以下调度信息
EVERY 5 minute STARTS now() ON COMPLETION PRESERVE ENABLE DO 
BEGIN
	DECLARE r_code CHAR(5) DEFAULT '00000';
	DECLARE r_msg TEXT;
	DECLARE v_error INTEGER;
	DECLARE	v_starttime DATETIME DEFAULT NOW();
	DECLARE v_randno INTEGER DEFAULT FLOOR(RAND()*100001);
	
	INSERT INTO mysql.t_event_history (dbname,eventname,starttime,randno) 
	#修改下面的作业名(该作业的名称)
	VALUES(DATABASE(),'job_update_status', v_starttime,v_randno);	
	
	BEGIN
		#异常处理段
		DECLARE CONTINUE HANDLER FOR SQLEXCEPTION  
		BEGIN
			SET  v_error = 1;
			GET DIAGNOSTICS CONDITION 1 r_code = RETURNED_SQLSTATE , r_msg = MESSAGE_TEXT;
		END;
		
		#此处为实际调用的用户程序过程
		CALL automaintain.pro_update_status();
	END;
	
	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;
	
END$$
DELIMITER ;

3.查询event

select * from mysql.event;

文章标题:mysqlevent建立模板(可记录执行履历)
文章分享:https://www.cdcxhl.com/article26/jjdscg.html

成都网站建设公司_创新互联,为您提供软件开发服务器托管网站设计搜索引擎优化营销型网站建设静态网站

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

绵阳服务器托管