溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql event建立模板(可記錄執行履歷)

發布時間:2020-08-08 21:04:19 來源:ITPUB博客 閱讀:211 作者:wwjfeng 欄目:MySQL數據庫
  1. 建立履歷記錄表

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;

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女