详细分析Mysql中的定时任务(Event事件)

news/2024/9/28 16:39:36/

目录

前言

基本的知识推荐阅读:

  1. 详细分析Mysql触发器的基本使用(图文解析)
  2. 详细分析SQL Server触发器的基本知识
  3. 详细分析Corn表达式(附Demo)
特性事件定时任务触发器
触发条件基于时间基于表中的 INSERT、UPDATE 或 DELETE 操作
使用场景定时清理、报表生成、自动化维护保证数据一致性、操作日志记录、自动级联操作
作用范围可以跨多个表、数据库中的任意对象只能作用于与触发器绑定的表
执行频率按时间间隔执行(如每小时、每天等)每次有数据变更(如插入、更新、删除)时立即执行
与时间的关系完全基于外部时间与时间无关,只与数据操作有关
执行的SQL可以执行复杂的、跨表的SQL操作只能与触发操作的表有关,常常用于表的自动操作

基本的Demo示例:

事件定时任务示例
场景:每天凌晨清理表 sessions 中超过 30 天未活跃的会话数据

CREATE EVENT clean_expired_sessions
ON SCHEDULE EVERY 1 DAY
STARTS '2024-09-23 00:00:00'
DODELETE FROM sessions WHERE last_active < NOW() - INTERVAL 30 DAY;

触发器示例
场景:在 users 表中插入一条新记录时,自动在 user_logs 表中记录该操作

CREATE TRIGGER after_user_insert
AFTER INSERT ON users
FOR EACH ROWINSERT INTO user_logs (user_id, action, log_time)VALUES (NEW.id, 'insert', NOW());

1. 基本知识

MySQL 中的事件定时任务(Event Scheduler)允许你在指定的时间点或时间间隔自动执行SQL语句,类似于其他数据库中的计划任务(Scheduler)或Linux中的cron任务

事件任务可以用于自动化数据库维护、数据归档、统计、清理过期数据等

主要特性:

  • 可以在未来某一时间点执行任务,或以固定的时间间隔重复执行
  • 任务可以单次执行,也可以重复执行
  • 不需要外部工具,如 cron,直接在 MySQL 内部进行调度
  • 可以暂停或删除任务

事件调度器是MySQL管理定时任务的模块,它在后台运行并监控所有定义的事件

相关的系统变量:

  • event_scheduler: 控制事件调度器是否启用
  • ON:开启事件调度器
  • OFF: 关闭事件调度器,事件不会自动运行
  • DISABLED:调度器被禁用

查看当前事件调度器状态:SHOW VARIABLES LIKE 'event_scheduler';

开启事件调度器:SET GLOBAL event_scheduler = ON;

2. Event事件

创建和管理事件:事件调度器中的每一个任务称为一个事件(Event)

创建事件时,需要指定触发的时间、是否循环执行,以及事件的具体SQL操作

创建单次执行的事件

CREATE EVENT event_name
ON SCHEDULE AT '2024-09-22 12:00:00'
DOUPDATE my_table SET my_column = 'value' WHERE id = 1;

创建重复执行的事件

CREATE EVENT event_name
ON SCHEDULE EVERY 1 HOUR
STARTS '2024-09-22 12:00:00'
DODELETE FROM my_table WHERE created_at < NOW() - INTERVAL 1 DAY;

删除事件

DROP EVENT IF EXISTS event_name;

修改事件

ALTER EVENT event_name
ON SCHEDULE EVERY 2 HOUR
DOINSERT INTO my_log (log_message) VALUES ('Scheduled task executed');

事件的组成部分

CREATE EVENT:定义事件
ON SCHEDULE: 定义任务的触发时间,AT:设定事件在指定的时间点执行。,EVERY:设定事件以固定的时间间隔执行(可结合 STARTS 和 ENDS 定义任务开始和结束时间)
DO:事件要执行的SQL语句
ENABLEDISABLE:决定事件是否启用
COMMENT:给事件添加注释

事件状态管理

启用或禁用事件

ALTER EVENT event_name ENABLE;
ALTER EVENT event_name DISABLE;

查看事件状态: 可以通过 INFORMATION_SCHEMA.EVENTS 查看数据库中所有的事件及其详细信息

SELECT * FROM INFORMATION_SCHEMA.EVENTS WHERE EVENT_NAME = 'event_name';

事件的生命周期

  • 永久事件:这些事件一旦被创建,会一直存在,直到手动删除或修改
  • 一次性事件:执行完一次之后就会自动删除

3. Demo

示例 1: 每天凌晨自动清理过期的会话数据
将在 2024-09-23 00:00:00 开始,每天运行一次。删除表 sessions 中最近 7 天未活跃的会话数据

CREATE EVENT clean_sessions
ON SCHEDULE EVERY 1 DAY
STARTS '2024-09-23 00:00:00'
DODELETE FROM sessions WHERE last_active < NOW() - INTERVAL 7 DAY;

示例 2: 每月自动生成销售报表
每月执行一次,将当月的销售总额插入到 monthly_sales_report 表中,CURRENT_TIMESTAMP 表示事件从当前时间开始执行

CREATE EVENT generate_sales_report
ON SCHEDULE EVERY 1 MONTH
STARTS CURRENT_TIMESTAMP
DOINSERT INTO monthly_sales_report (report_month, total_sales)SELECT DATE_FORMAT(NOW(), '%Y-%m'), SUM(amount) FROM sales WHERE created_at >= DATE_SUB(NOW(), INTERVAL 1 MONTH);

示例 3: 一次性执行的临时任务
该事件将在 2024-09-25 14:00:00 执行一次,将最近 30 天登录过的用户状态更新为 ‘active’

CREATE EVENT temp_task
ON SCHEDULE AT '2024-09-25 14:00:00'
DOUPDATE user_data SET status = 'active' WHERE last_login > NOW() - INTERVAL 30 DAY;

http://www.ppmy.cn/news/1530690.html

相关文章

校园美食导航:Spring Boot技术的美食发现之旅

第二章 系统分析 2.1 可行性分析 可行性分析的目的是确定一个系统是否有必要开发、确定系统是否能以最小的代价实现。其工作主要有三个方面&#xff0c;分别是技术、经济和社会三方面的可行性。我会从这三个方面对网上校园周边美食探索及分享平台进行详细的分析。 2.1.1技术可行…

【Webpack】生命周期

概述 Webpack 的生命周期是指从启动到结束整个过程中会经历的一系列步骤。简单来说&#xff0c;Webpack 的生命周期分为以下几个主要阶段&#xff1a; 1&#xff09;初始化&#xff1a;Webpack 读取配置文件&#xff0c;初始化参数。 2&#xff09;编译&#xff1a;根据入口文…

银从初级个人理财_09_第三章第三节

一、单选题 一般而言&#xff0c;在面对通货膨胀压力的情况下&#xff0c;()投资具有保值增值的作用。 现金 固定收益产品 黄金 储蓄 房地产信托是指房地产拥有者将该房地产委托给信托公司&#xff0c;由信托公司按照委托者的要求进行()。 物业经营 租赁、经营 租售 …

Python pyppeteer 与playwright 模拟浏览器请求 部署服务器遇到的坑

在服务器部署遇到的问题 在服务器上部署后如果遇到代码执行卡主问题 通过debug 显示 代码到 browser await launch(headlessFalse)卡主了 ,由于服务器没有浏览器的图形化环境,所以只能将修改为无头浏览器的模式启动 browser await launch(headlessTrue) async def crawling…

linux常见指令与权限【第四课】

19.tar指令&#xff08;重要&#xff09;&#xff1a;打包/解包&#xff0c;不打开它&#xff0c;直接看内容 tar [-cxtzjvf] &#xff1a; -c &#xff1a;建立一个压缩文件的参数指令 (create 的意思 ) &#xff1b; -x &#xff1a;解开一个压缩文件的参数指令&#xff…

Elasticsearch实战应用

Elasticsearch作为一个强大的分布式搜索引擎&#xff0c;因其高性能、灵活性和易扩展性&#xff0c;广泛应用于多个领域。本文将探讨几个实际应用中的Elasticsearch&#xff0c;并分享如何高效地利用这一工具来提升系统性能和用户体验。 一、前言 在现代应用中&#xff0c;数…

【吊打面试官系列-MySQL面试题】MySQL 数据库作发布系统的存储,一天五万条以上的增量,预计运维三年,怎么优化?

大家好&#xff0c;我是锋哥。今天分享关于【MySQL 数据库作发布系统的存储&#xff0c;一天五万条以上的增量&#xff0c;预计运维三年,怎么优化&#xff1f;】面试题&#xff0c;希望对大家有帮助&#xff1b; MySQL 数据库作发布系统的存储&#xff0c;一天五万条以上的增量…

17121 求二叉树各种节点数

### 思路 1. 使用先序遍历的方式构造二叉树。 2. 使用递归函数 CreateBiTree 来构造二叉树。 3. 使用递归函数 CountNodes 来统计度为2、度为1和度为0的节点数。 ### 伪代码 1. 定义二叉树节点结构 BiTNode 和二叉树指针 BiTree。 2. 定义 CreateBiTree 函数&#xff1a; -…