mysql 事件

-- 查询事件(任务调度器) 状态
   show variables like '%event_scheduler%';

-- 启动任务调度器
   SET GLOBAL event_scheduler = ON
-- 关闭任务调度器
   SET GLOBAL event_scheduler = OFF

-- 开启事件
   ALTER EVENT event_user ENABLE;
-- 关闭事件
   ALTER EVENT event_user DISABLE;


-- 查询当前的事件information_schema下
   SELECT * FROM information_schema.events;

-- 查询当前的事件mysql
   SELECT*FROM mysql.`event`


-- 创建 事件 调用过程程序

    CREATE DEFINER=`root`@`localhost` EVENT test_event
    ON SCHEDULE EVERY 5 SECOND
    ON COMPLETION PRESERVE ENABLE
    DO CALL test_function();

-- 创建事件 调用函数
-- 实例一
    CREATE DEFINER=`root`@`localhost` EVENT test_function_event
    ON SCHEDULE EVERY 5 SECOND
    ON COMPLETION PRESERVE ENABLE
    DO CALL custom_function(1);
-- 实例二
    CREATE EVENT IF NOT EXISTS event_user
    ON SCHEDULE EVERY 5 SECOND
    ON COMPLETION PRESERVE
    COMMENT '新增用户信息定时任务'
    DO INSERT INTO goods(gmt_create_sys,gmt_update_sys,goods_name,goods_price) VALUES(now(),now(),'event_goods',11)

-- 删除事件
    DROP EVENT IF EXISTS test_function_event
### 如何调整或调度 MySQL 事件(Event Scheduler) #### 调整 Event Scheduler 的状态 要控制 MySQL 事件调度器的状态,可以通过设置 `event_scheduler` 系统变量来实现。该变量有三个可能的值:`ON`, `OFF`, 和 `DISABLED`。当其值为 `ON` 时表示事件调度器已启用;如果为 `OFF` 则表示禁用但仍然保留定义好的事件;而 `DISABLED` 表示完全关闭并忽略所有的事件配置。 可以在运行时动态更改此参数或者通过 my.cnf 文件永久生效[^3]: ```sql SET GLOBAL event_scheduler = ON; ``` 上述语句会立即激活当前实例上的事件调度功能。 #### 创建新的 MySQL 事件 为了新建一个周期性的任务,需要用到 CREATE EVENT 命令。下面是一个简单的例子展示如何每天凌晨两点删除超过一个月的日志记录表中的条目[^2]: ```sql CREATE EVENT IF NOT EXISTS cleanup_old_logs ON SCHEDULE EVERY 1 DAY STARTS '2023-09-01 02:00:00' DO DELETE FROM logs WHERE created_at < DATE_SUB(CURDATE(), INTERVAL 1 MONTH); ``` 这里需要注意的是,在创建之前应该确认是否有足够的权限去执行这样的操作以及确保所指定的时间格式正确无误。 #### 修改现有的 MySQL 事件 对于已经存在的事件对象来说,我们无法直接对其进行编辑。但是可以先将其丢弃再重新建立一个新的同名替代品达到目的: ```sql ALTER EVENT existing_event_name DISABLE; -- 或者 DROP EVENT existing_event_name; -- 接着按照需求重建它... CREATE EVENT ... ``` 另外一种方法就是利用 ALTER EVENT 来改变某些属性而不必彻底移除原事件: ```sql ALTER EVENT existing_event_name RENAME TO new_event_name; ALTER EVENT existing_event_name ENABLE|DISABLE; ``` 以上两种方式都可以满足不同场景下的修改要求。 #### 删除不再需要的 MySQL 事件 最后,如果你发现某个特定的任务已经没有必要继续存在下去,则可以直接把它给删掉即可: ```sql DROP EVENT unnecessary_event; ``` 这一步骤非常简单明了,只需提供准确的目标名称就可以了。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值