1. 程式人生 > >MySQL-事件總結

MySQL-事件總結

#查詢事件變數,如果查詢不到變數,說明資料庫版本過低,不支援事件。
SHOW VARIABLES LIKE 'event_scheduler';
#開啟事件,如果想要每次重啟資料庫服務後,事件仍然生效需要在mysql.ini檔案中加入event_scheduler = ON; 的語句
SET GLOBAL event_scheduler = ON;
#查詢資料庫所有建立的事件
SELECT * FROM mysql.event;
#開啟事件任務
ALTER EVENT event1 ENABLE;
#關閉事件任務
ALTER EVENT event1 DISABLE;
#檢視事件的定義
SHOW CREATE EVENT event1;

#建立事件語法
CREATE
[DEFINER = { USER | CURRENT_USER }]
EVENT
[IF NOT EXISTS]
event_name
ON SCHEDULE SCHEDULE
[ON COMPLETION [NOT] PRESERVE]
[ENABLE | DISABLE | DISABLE ON SLAVE]
[COMMENT 'comment']
DO event_body;
SCHEDULE:
AT TIMESTAMP [+ INTERVAL INTERVAL] ...
| EVERY INTERVAL
[STARTS TIMESTAMP [+ INTERVAL INTERVAL] ...]
[ENDS TIMESTAMP [+ INTERVAL INTERVAL] ...]
INTERVAL:
quantity {YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE |WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE |DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND}

#event_name表示事件名稱
#schedule表示觸發點,AT timestamp一般用於只執行一次。EVERY interval一般用於週期性執行,可以設定開始時間和結束時間。
#ON COMPLETION PRESERVE:表示任務執行之後仍保留
#ON COMPLETION NOT PRESERVE:表示任務執行完成後不保留
#ENABLE|DISABLE:表示設定啟用或者禁止這個事件。
#COMMENT:添加註釋

#測試表
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '主鍵',
`name` VARCHAR(200) NOT NULL COMMENT '收貨人',
`address` VARCHAR(100) NOT NULL COMMENT '收貨地址',
`addtime` DATETIME NOT NULL COMMENT '新增時間',
PRIMARY KEY (`id`)
) ENGINE=INNODB DEFAULT CHARSET=utf8;

#測試儲存過程
DELIMITER $$
DROP PROCEDURE IF EXISTS `ADD_USER`$$
CREATE PROCEDURE `ADD_USER`(IN add_time DATETIME)
BEGIN
INSERT INTO `user`(NAME, address,ADDTIME) VALUES('AT','AT',add_time);
END$$
DELIMITER ;

#清空表
TRUNCATE TABLE `user`;

#1.每隔3秒
DROP EVENT IF EXISTS `event1`;
DELIMITER ;;
CREATE EVENT `event1` ON SCHEDULE EVERY 3 SECOND ON COMPLETION PRESERVE DISABLE COMMENT ''
DO
BEGIN
INSERT INTO `user`(NAME, address,ADDTIME) VALUES('test1','test1',NOW());
END
;;
DELIMITER ;

#2.每天幾點幾分
DROP EVENT IF EXISTS `event3`;
DELIMITER ;;
CREATE EVENT `event3` ON SCHEDULE EVERY 1 DAY STARTS DATE_ADD(DATE_ADD(CURDATE(),INTERVAL 3 HOUR),INTERVAL 30 MINUTE) ON COMPLETION PRESERVE ENABLE COMMENT ''
DO
BEGIN
CALL ADD_USER(NOW());
END
;;
DELIMITER ;

#9號凌晨1點
SELECT DATE_ADD(DATE_SUB(CURDATE(),INTERVAL DAY(CURDATE())-9 DAY),INTERVAL 1 HOUR);
#1分鐘後
SELECT NOW()+INTERVAL 1 MINUTE;
#凌晨3點
SELECT DATE_ADD(CURDATE(),INTERVAL 3 HOUR);
#凌晨3點30分
SELECT DATE_ADD(DATE_ADD(CURDATE(),INTERVAL 3 HOUR),INTERVAL 30 MINUTE);