1. 程式人生 > >mysql建立event事件

mysql建立event事件

一、基本語法

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】一般用於只執行一次,一般使用時可以使用當前時間加上延後的一段時間,例如:AT CURRENT_TIMESTAMP + INTERVAL 1 HOUR。也可以定義一個時間常量,例如:AT '2006-02-10 23:59:00';【EVERY interval】一般用於週期性執行,可以設定開始時間和結束時間。
  • ON COMPLETION [NOT] PRESERVE,預設是執行完之後會自動刪除。如果想保留該事件使用ON COMPLETION PRESERVE;如果不想保留也可以設定ON COMPLETION [NOT] PRESERVE
  • ENABLE | DISABLE表示設定啟用或者禁止這個事件。
  • COMMENT 表示增加註釋。

使用示例:

delimiter |
CREATE EVENT e
    ON SCHEDULE
      EVERY 5 SECOND
      on completion preserve enable
    DO
      BEGIN
        DECLARE v INTEGER;
        DECLARE CONTINUE HANDLER FOR SQLEXCEPTION BEGIN END;
        SET v = 0;
        WHILE v < 5 DO
          INSERT INTO t1 VALUES (0);
          UPDATE t2 SET s1 = s1 + 1;
          SET v = v + 1;
        END WHILE;
    END |
delimiter ;

二、事件的基本使用方法

1、一般的修改語法與建立語法類似:

ALTER EVENT myevent
    ON SCHEDULE
      EVERY 12 HOUR
    STARTS CURRENT_TIMESTAMP + INTERVAL 4 HOUR;

2、禁用事件

ALTER EVENT myevent
    DISABLE;

3、啟用事件

ALTER EVENT myevent
    ENABLE;

4、使用事件之前要確保event功能是開啟的

-- 檢視event_scheduler變數是否開啟,ON|1表示開啟;OFF|0表示關閉。
show VARIABLES LIKE '%sche%';
-- 由於這是全域性變數,需要root使用者才能執行。
SET GLOBAL event_scheduler = 1;

5、查詢資料庫所有事件

select * from  mysql.event;