天天看點

mysql 啟動事件 啟動觸發器功能

事件排程器有時也可稱為臨時觸發器(temporal triggers),

因為事件排程器是基于特定時間周期觸發來執行某些任務,而觸發器(Triggers)是基于某個表所産生的事件觸發的,差別也就在這裡。 

在使用這個功能之前必須確定event_scheduler已開啟,可執行 

開啟:

①(開啟事件觸發器)

<code>SET GLOBAL event_scheduler = </code><code>1</code><code>;</code>

或我們可以在配置my.ini檔案 中加上 event_scheduler = 1

②或  

<code>SET GLOBAL event_scheduler = ON;</code>

來開啟,也可以直接在啟動指令加上“–event_scheduler=1”,例如: 

mysqld ... --event_scheduler=1 

要檢視目前是否已開啟事件排程器,可執行如下SQL: 

<code>SHOW VARIABLES LIKE </code><code>'event_scheduler'</code><code>; </code>

<code>或 </code>

<code>SELECT @</code><code>@event_scheduler</code><code>;</code>

或 

擁有 SUPER 權限的賬戶執行 SHOW PROCESSLIST 就可以看到這個線程了。

在使用事件這個功能,首先要保證你的mysql的版本是5.1以上,然後還要檢視你的mysql伺服器上的事件是否開啟。

如果看到event_scheduler為on

或者PROCESSLIST中顯示有event_scheduler的資訊說明就已經開啟了事件。如果顯示為off

或者在PROCESSLIST中檢視不到event_scheduler的資訊,那麼就說明事件沒有開啟,我們需要開啟它。

其他:

<code>-- 開啟事件排程的支援</code>

<code>-- 列出事件</code>

<code>SHOW EVENTS;</code>

<code>SHOW CREATE EVENT del_user;</code>

<code>  </code> 

<code>-- 查詢觸發器是否啟動。</code>

<code>-- 定義存儲過程  (修改test表裡面的id都為</code><code>5</code><code>)</code>

<code>DELIMITER </code><code>//</code>

<code>DROP PROCEDURE IF EXISTS usp_update_test;</code>

<code>CREATE PROCEDURE usp_update_test()</code>

<code>-- expire_interval: the unit is hour</code>

<code>-- delete_per_count: specify the count </code><code>do</code> <code>every delete operation</code>

<code>BEGIN</code>

<code>    </code><code>DECLARE id INT;</code>

<code>        </code><code>SET id=</code><code>5</code><code>;   </code>

<code>        </code><code>update test set id=id;</code>

<code>END </code><code>//</code>

<code>DELIMITER ;</code>

<code>-- 定義事件  (一分鐘執行一次上面的存儲過程)</code>

<code>DROP EVENT IF EXISTS del_test;</code>

<code>CREATE EVENT del_test</code>

<code>ON SCHEDULE EVERY </code><code>1</code> <code>MINUTE</code>

<code>DO</code>

<code>CALL usp_update_test()</code>

<code></code>

      本文轉自建波李 51CTO部落格,原文連結:http://blog.51cto.com/jianboli/1884180,如需轉載請自行聯系原作者