mysql创建定时任务执行存储过程

存储过程已添加好:https://blog.csdn.net/YXWik/article/details/127283316
在这里插入图片描述
1.创建定时器用来执行存储过程函数

create event delete_data
on schedule every 10 second
do call delete_data();

这里的第一行代表的创建名称为delete_data的事件
第二行是执行周期为每10秒执行一次
第三行是该事件的操作内容,执行我们的存储函数
这里默认是创建好后立即执行
如果想要创建后并不开始生效可以增加 on completion preserve disable

2.查看定时任务事件

SELECT event_name,event_definition,interval_value,interval_field,status FROM information_schema.EVENTS;

在这里插入图片描述

show variables like '%sche%' ;

在这里插入图片描述

如果Value值为OFF,则需要开启。需要超级权限

set global event_scheduler=1 ;

3.删除定时任务

drop event delete_data;

4.定时任务的开启关闭

alter event delete_data on completion preserve enable; //开启定时任务
alter event delete_data on completion preserve disable;//关闭定时任务

5.定时周期
上面用到的是每10秒执行一次
on schedule every 10 second
还有其他执行–关键字

on schedule every 1 second //每秒执行1次
on schedule every 1 minute //每一分钟执行1次
on schedule every 1 day //每一天执行1次
on schedule at current_timestamp()+interval 1 day //1天后执行
on schedule at current_timestamp()+interval 10 minute //10分钟后执行
on schedule at '2022-10-01 20:00:00' //在2022年10月1日,晚上20点执行
on schedule every 1 day starts current_timestamp()+interval 1 day ends current_timestamp()+interval 1 month 
//1天后开始每天都执行执行到下个月底

on schedule every 1 day ends current_timestamp()+interval 5 day 
//从现在起每天执行,执行5天

ON SCHEDULE EVERY 1 DAY STARTS '2022-10-12 00:00:00'
// 从2022年10月12号0点执行,每天执行

6.常用的语法关键字:
NOT PRESERVE 任务完成后清除定时器, (默认)
PRESERVE 任务完成后不清除定时器
EVERY 周期执行
STARTS ENDS 在某个时间段执行
AY 某个时间点执行
ENDS 结束定时器时间
INTERVAL 间隔(时间)

7.定时器语法结构:

CREATE EVENT 定时器名称
    ON  SCHEDULE  xx     -- 定时器从什么开始执行的 (必须)
	ENDS CURRENT_TIMESTAMP  xx    -- 定时器开始后在什么时候结束 (非必选)
    ON COMPLETION xx       -- 定时器清除策略 (默认就行)
DO  sql语句   -- 定时器执行的内容,只允许一条sql语句以分号结束 (必须)

  • 6
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在MySQL创建一个定时执行存储过程,您可以按照以下步骤进行操作: 1. 首先,您需要创建一个定时器来执行存储过程函数。可以使用以下语句创建一个定时器,并设置执行的时间间隔: ```sql CREATE EVENT delete_data ON SCHEDULE EVERY 10 SECOND DO CALL delete_data(); ``` 2. 接下来,您需要声明一个存储过程。您可以使用以下语句创建一个名为`insert_dept`的存储过程,并在其中添加随机数据到`dept`表: ```sql DELIMITER $$ CREATE PROCEDURE `insert_dept`(max_num INT) BEGIN DECLARE i INT DEFAULT 0; SET autocommit = 0; REPEAT SET i = i + 1; INSERT INTO dept (id, name) VALUES (rand_num(1, 500000), 'ljf'); UNTIL i = max_num END REPEAT; COMMIT; END$$ ``` 3. 最后,您可以创建一个名为`test_d2`的存储过程,其中包含需要定时执行的操作。以下是一个示例,创建一个名为`test_ddd`的表,并将当前时间插入其中: ```sql CREATE PROCEDURE test_d2() BEGIN DROP TABLE IF EXISTS test_ddd; CREATE TABLE test_ddd AS SELECT NOW(); END; ``` 通过以上步骤,您可以在MySQL创建一个定时执行存储过程。请注意,具体的语法和细节可能会因MySQL版本而有所不同,以上示例仅供参考。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [mysql创建定时任务执行存储过程](https://blog.csdn.net/YXWik/article/details/127263626)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [mysql存储过程实现定时任务执行](https://blog.csdn.net/u011066470/article/details/123946434)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值