mysql创建event事件

本文详细介绍了MySQL中事件调度器的使用方法,包括创建事件的基本语法、如何设置事件的触发条件、启用和禁用事件,以及如何确保event功能正确开启。通过示例展示了如何创建周期性执行的事件。

mysql创建event事件

2016年08月23日 23:06:58 阅读数:5972

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.youkuaiyun.com/u013755987/article/details/52294656

一、基本语法

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}
  • 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;12

4、使用事件之前要确保event功能是开启的

-- 查看event_scheduler变量是否开启,ON|1表示开启;OFF|0表示关闭。
show VARIABLES LIKE '%sche%';
-- 由于这是全局变量,需要root用户才能执行。
SET GLOBAL event_scheduler = 1;

5、查询数据库所有事件

select * from mysql.event;

MySQL 中,可以通过 `DROP EVENT` 语句删除一个或多个已创建事件event)。事件是存储在数据库中的一种对象,用于在指定的时间或间隔自动执行某些任务。删除事件的操作需要具有足够的权限,例如 `EVENT` 权限。 ### 删除事件的基本语法如下: ```sql DROP EVENT [IF EXISTS] event_name; ``` - `IF EXISTS` 是可选参数,用于防止在指定事件不存在时产生错误。如果事件不存在且未使用该参数,MySQL 将返回错误信息。 - `event_name` 是要删除的事件的名称。 例如,要删除名为 `daily_cleanup` 的事件,可以使用以下语句: ```sql DROP EVENT IF EXISTS daily_cleanup; ``` 此语句将从数据库中永久删除事件 `daily_cleanup`,并且无法恢复。执行该操作后,事件将不再出现在 `INFORMATION_SCHEMA.EVENTS` 表中[^1]。 ### 注意事项: 1. **权限要求**:用户必须具有对事件的 `ALTER` 或 `DROP` 权限,才能执行删除操作。 2. **事件调度器状态**:如果事件调度器(`event_scheduler`)被禁用,删除事件的操作仍然可以执行,因为该操作仅影响事件定义,而不影响其执行状态。 3. **依赖关系**:如果事件依赖于某些表、存储过程或其他数据库对象,删除事件不会影响这些对象本身。 ### 查看当前事件 在删除事件之前,可以通过以下语句查看当前数据库中存在的事件: ```sql SELECT * FROM information_schema.EVENTS; ``` 此查询将列出所有事件及其详细信息,包括事件名称、所属数据库、定义者、执行时间等。 ### 示例:删除事件并验证 ```sql -- 查看所有事件 SELECT EVENT_NAME, EVENT_SCHEMA, DEFINER FROM information_schema.EVENTS WHERE EVENT_SCHEMA = 'your_database'; -- 删除指定事件 DROP EVENT IF EXISTS your_database.your_event; -- 再次查询以确认事件是否已删除 SELECT EVENT_NAME, EVENT_SCHEMA, DEFINER FROM information_schema.EVENTS WHERE EVENT_SCHEMA = 'your_database'; ``` 通过上述步骤,可以确保事件被正确删除,并验证删除操作是否成功。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值