天天看点

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,如需转载请自行联系原作者