【SQL】使用Navicat创建MySQL定时任务重复执行某个sql语句

一.首先在查询中新建一个存储过程

大致语法为:

CREATE PROCEDURE func()
BEGIN
/*
需要执行的sql语句
*/
END

我的示例为:

【SQL】使用Navicat创建MySQL定时任务重复执行某个sql语句_第1张图片

然后保存为该查询为update_temper1

【SQL】使用Navicat创建MySQL定时任务重复执行某个sql语句_第2张图片

二.使用Navicat创建一个事件

点击Navicat的事件->新建事件

【SQL】使用Navicat创建MySQL定时任务重复执行某个sql语句_第3张图片

在定义中调用之前保存的存储过程CALL func()

【SQL】使用Navicat创建MySQL定时任务重复执行某个sql语句_第4张图片

然后设置计划,也就是设置执行周期和事件

【SQL】使用Navicat创建MySQL定时任务重复执行某个sql语句_第5张图片

然后保存为update_temper1_Event即可,事件就会开始执行

注:如何查看SQL时候开启事件功能及事件的常用指令

以MySQL为例

此时进入SQL的命令列

1、首先,必须确认mysql是否开启了定时任务

查看event是否开启 : SHOWVARIABLES LIKE '%event_sche%';

mysql> SHOW VARIABLES LIKE '%event_sche%';
+----------------+-------+
| Variable_name   | Value |
+----------------+-------+
| event_scheduler | ON   |
+----------------+-------+
1 row in set (0.08 sec)

mysql> 

将事件计划开启 :set global event_scheduler =1;//参数说明(0或off为关闭,1或on为开启)

mysql> set global event_scheduler =1;
Query OK, 0 rows affected (0.06 sec)

mysql> 

2、对于Event的常用操作(新建查询页面):
查看:SHOW EVENTS;

【SQL】使用Navicat创建MySQL定时任务重复执行某个sql语句_第6张图片
开启事件:
ALTER EVENT update_temper1_Event ON COMPLETION PRESERVE ENABLE;

关闭事件:
ALTER EVENT update_temper1_Event ON COMPLETION PRESERVE DISABLE;

删除事件:DROP EVENT IF EXISTS update_temper1_Event;

--------------------------------------------------------------------------------------------------------------------------------------------------------------------

参考于:mysql 数据库Event定时任务使用详解(Navicat 及直接SQL语句创建)

你可能感兴趣的:(Mysql)