您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關mysql如何創建event并實現保存event執行history的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
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 EVENT job_del_expire_privileges ON SCHEDULE
#修改以下調度信息
EVERY 10 minute STARTS current_timestamp 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_del_expire_privileges', 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_del_expire_request();
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 ;
感謝各位的閱讀!關于“mysql如何創建event并實現保存event執行history”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。