mysql定时任务

1、首先,需要确保 MySQL 服务器启用了事件调度器(Event Scheduler)。可以通过在 MySQL 命令行界面中执行以下命令来检查:

SHOW VARIABLES LIKE 'event_scheduler';

2、如果该变量的值为 OFF,则需要将其设置为 ON:

SET GLOBAL event_scheduler = ON;

3、然后,创建一个存储过程(Stored Procedure),在其中编写要执行的操作。例如,以下存储过程会在表 normative_documents 中修改指定时间之前的数据状态:

CREATE DEFINER=`root`@`%` PROCEDURE `handleEffect`()
BEGIN
  UPDATE  normative_documents set ageing = '1' WHERE  administration_time <= NOW()  and ageing = '2';
END

4、接下来,创建一个事件(Event),指定要执行的存储过程以及执行时间。例如,以下事件会在每天凌晨 1 点执行存储过程 my_procedure():

CREATE EVENT my_event
ON SCHEDULE EVERY 1 DAY
STARTS '2023-04-12 01:00:00'
DO CALL handleEffect();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值