MySQL 定时器

MySQL 定时器

MySQL 定时器

工作中常存在一些固定任务,需要周期性执行。

有些需要在服务中,也有一些完全存在于数据层面。

对于数据层面的任务,可以借助定时器,而不需要在服务中执行。

这里介绍的是MySQL数据库的定时器。

功能开启

首先查看定时器功能是否开启

sql 复制代码
SHOW VARIABLES LIKE 'event_scheduler';

结果集中,OFF表示关闭 , ON表示开启。

若为OFF,则需要开启该功能:

sql 复制代码
SET GLOBAL event_scheduler = 'ON'; 

sql 复制代码
SET GLOBAL event_scheduler = 1; 

此处注意,需要 root 用户权限 才能执行。

使用这种方式,若MySQL服务后续重启(虽然通常很少重启,但也会有的),定时器功能依然会恢复关闭。

可以通过修改配置文件的方式,调整定时器默认开关。

方法也比较简单,找到mysql根目录下 my.ini 文件,打开并在 [mysqld] 标记下方添加:

event_scheduler = ON

示例

创建定时器:

sql 复制代码
CREATE EVENT [EVENT_NAME] ON SCHEDULE EVERY 1 QUARTER STARTS DATE_ADD(
        DATE_ADD(DATE(CONCAT(YEAR(CURDATE()), '-', ELT(QUARTER(CURDATE()), 1, 4, 7, 10), '-', 1)), INTERVAL 1 QUARTER),
        INTERVAL 1 HOUR) ON COMPLETION PRESERVE DO CALL PROCEDURE_NAME();

该定时器设置为每个季度第一天的凌晨一点,执行 PROCEDURE_NAME() 任务。

注意

有几个关键点需要注意:

  1. EVENT_NAME 名称最大长度可以是64个字节,同一数据库中唯一。
  2. ON SCHEDULE 计划任务,可以像上述示例一样,使用EVERY关键字,创建重复执行的任务;也可以使用AT,创建固定时间点执行的任务。
  3. DO [sql_statement],上述示例中使用的是DO CALL PROCEDURE_NAME(),执行存储过程;也可以是具体的SQL语句。
    如果是复合语句,按照顺序写在BEGIN和END标识符中即可,如:
sql 复制代码
BEGIN
	DROP TABLE TEST_TABLE;
	CALL PROCEDURE_NAME();
END
  1. 删除已经创建的事件使用DROP EVENT语句。
    若事件正在执行中,将会在执行结束后删除。
    使用DROP USER和DROP DATABASE 语句同时会将包含其中的事件删除。
  2. ON COMPLETION PRESERVE,在任务执行结束后,保留定时器。若设置为NOT PRESERVE,则在任务结束后清除定时器,若未设置,默认NOT PRESERVE。
相关推荐
颜颜yan_9 分钟前
时序数据库选型指南:工业物联网时代如何选择数据底座
数据库·物联网·时序数据库
云和数据.ChenGuang21 分钟前
Logstash配置文件的**语法解析错误**
运维·数据库·分布式·rabbitmq·jenkins
CICI1314141340 分钟前
焊接机器人负载能力选择标准
网络·数据库·人工智能
minhuan1 小时前
大模型应用:从交易行为到实时反欺诈:向量数据库驱动的智能风控实践.33
数据库·向量数据库·大模型应用·chromadb数据库
晴天¥1 小时前
Oracle中的安全管理(用户、权限、角色)
数据库·安全·oracle
Jelly-小丑鱼1 小时前
Linux搭建SQLserver数据库和Orical数据库
linux·运维·数据库·sqlserver·oracal·docker容器数据库
JIngJaneIL1 小时前
基于springboot + vue健康管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·后端
秋饼1 小时前
【三大锁王争霸赛:Java锁、数据库锁、分布式锁谁是卷王?】
java·数据库·分布式
zhcf1 小时前
【MySQL】聚簇索引与非聚簇索引
数据库·mysql
小帅学编程2 小时前
JDBC学习
数据库·学习·oracle