详细分析Mysql中的定时任务(Event事件)
目录
- 前言
- 1. 基本知识
- 2. Event事件
- 3. Demo
前言
基本的知识推荐阅读:
- 详细分析Mysql触发器的基本使用(图文解析)
- 详细分析SQL Server触发器的基本知识
- 详细分析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语句
ENABLE或DISABLE:决定事件是否启用
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;
相关文章:
详细分析Mysql中的定时任务(Event事件)
目录 前言1. 基本知识2. Event事件3. Demo 前言 基本的知识推荐阅读: 详细分析Mysql触发器的基本使用(图文解析)详细分析SQL Server触发器的基本知识详细分析Corn表达式(附Demo) 特性事件定时任务触发器触发条件基于…...
SpinalHDL之语义(Semantic)(三)
本文作为SpinalHDL学习笔记第七十一篇,介绍SpinalHDL的规则(Rules)。 目录: 1.简介(Introduction) 2.并⾏性(Concurrency) 3.以最后赋值为准(Last valid assignment wins) 4.Scala下的信号和寄存器的内在联系(Signal and register interactions with Scala)(OOP引⽤+函数…...
SpringBoot 请求和响应
1. Spring Boot 请求与响应概述 在 Spring Boot 开发中,客户端通过浏览器发起请求,后端使用内置的 Tomcat Web 服务器处理请求,返回响应数据。请求和响应的过程遵循 HTTP 协议。Spring Boot 的核心 Servlet 程序是 DispatcherServlet&#x…...
LQR算法核心思想
本章以倒立摆为解决目的 什么是线性二次型控制器(LQR) 开环系统 即状态变量的倒数 系统的状态空间矩阵A * 系统状态变量x A状态矩阵:描述系统本身物理特性的一个矩阵,它是由系统本身的机械结构、物理结构决定的,无法…...
AI大模型之旅-最强开源文生图工具Stable Diffusion WebUI 教程
1.1克隆 Automatic1111 的 GitHub 仓库 在你想安装 Web UI 的文件夹路径下执行 git clone https://github.com/AUTOMATIC1111/stable-diffusion-webui 这将会克隆整个仓库到本地。 这里会默认访问 https://huggingface.co/ 下载 因此需要魔法 1.2 进入仓库目录 cd stable-di…...
WinForm程序嵌入Web网页
文章目录 前言一、三方库或控件的选择测试二、Microsoft Edge WebView2安装、使用步骤1.安装2.使用 前言 由于此项目需要winform客户端嵌入web网页并于JAVA端交互数据,所以研究了一下嵌入web网页这部分,趟了一遍雷,这里做下记录。 一、三方库…...
Redis string类型hash类型
string类型 类型介绍 在Redis中的所有的key都是string类型,而value的类型有多种。 Redis中的字符串是直接按照二进制的方式进行存储的,也就是不会做任何的编码转换,存的是什么,取出来的就是什么。这样一般来说,Redi…...
Solidity智能合约中的异常处理(error、require 和 assert)
Solidity 中的三种抛出异常方法:error、require 和 assert 在 Solidity 开发中,异常处理是确保智能合约安全性和正确性的关键步骤。Solidity 提供了三种主要方法来抛出异常:error、require 和 assert。本文将详细介绍这三种方法的用途、实现方…...
True NAS禁用ipv6
在 TrueNAS Scale 中,禁用 IPv6 的方法如下:12 进入 System->Advanced->Sysctl,设置一个 sysctl 可调整变量 net.ipv6.conf.all.disable_ipv6,值为 1,以完全禁用 IPv6。\...
笔记整理—linux进程部分(2)使用fork创建进程
为什么要创建进程,首先每个程序的运行都需要一个进程;多进程实现宏观上的并行。 fork的原理,是进程的分裂生长模式。如果操作系统需要一个新的进程,那么就会以cp的方法得到一个新的进程,此时老的进程是父进程ÿ…...
在Python中实现多目标优化问题(6)
在Python中实现多目标优化问题 在Python中实现多目标优化,除了传统的进化算法(如NSGA-II、MOEA/D)和一些基于机器学习的方法外,还有一些新的方法和技术。这些新方法通常结合了最新的研究成果,提供了更高效的解决方案。…...
Java EE中的编码问题及解决方案
Java EE中的编码问题及解决方案 在Java EE开发中,处理字符编码是确保数据正确传输和显示的重要环节。不同的编码不一致会导致乱码,影响用户体验。本文将总结在Java EE中可能遇到的编码问题及其解决方案。 1. 输入数据编码问题 在表单提交时,…...
9月27日,每日信息差
第一、中国科学家团队在干细胞治疗领域取得重要突破,通过化学重编程技术成功制备出胰岛细胞,并用于移植治疗一名 1 型糖尿病患者,实现了临床功能性治愈。相关研究成果已发表在国际权威期刊《细胞》上。 第二、交通运输部公路局局长周荣峰在国…...
什么是 Angular 开发中的 Dumb components
Dumb components,在 Angular 开发中也被称为 Presentational components,它们的主要职责是通过展示数据和触发事件,把业务逻辑和 UI 表现分离开来。Dumb components 只通过 Input() 接收数据,Output() 向外发送事件,不…...
Docker 进入容器运行命令的详细指南
Docker 进入容器运行命令的详细指南 Docker 是一个开源的容器化平台,广泛应用于开发和生产环境中。它允许开发者打包应用程序及其依赖项到容器中,并能够在不同的平台上快速部署和运行。容器通常是独立且隔离的,但在开发、调试或维护过程中&a…...
如何禁止非真实用户的ip访问网站服务器
为了禁止非真实用户的IP访问网站服务器,可以采用多种技术手段和策略。以下是一些常用的方法: 1. 使用IP黑名单和白名单 黑名单:定期更新和维护一个IP黑名单,阻止已知的恶意IP地址或数据中心IP访问网站。白名单:对于特…...
探索SpringBoot:学科竞赛管理项目开发
2 相关技术简介 2.1Java技术 Java是一种非常常用的编程语言,在全球编程语言排行版上总是前三。在方兴未艾的计算机技术发展历程中,Java的身影无处不在,并且拥有旺盛的生命力。Java的跨平台能力十分强大,只需一次编译,任…...
ultralytics yolo v8 示例:加载官方模型进行推理
Ultralytics YOLO 是计算机视觉和 ML 领域专业人士的高效工具。 安装 ultralytics 库: pip install ultralytics 实现代码如下: import cv2 from ultralytics import YOLO# 加载预训练的 YOLOv8n 模型 ckpt_dir "./ckpt/" # 模型缓存地址…...
【中间件学习】Nginx快速入门(为了配置一个项目)
-----------------------------本文章借鉴遇见狂神说--------------------------- 一、一个产品出现瓶颈?? 在一个产品刚刚上线的时候,并发量小,用户使用的少,所以在低并发的情况下,一个jar包启动应该就够…...
鸿蒙harmonyos next flutter通信之MethodChannel获取设备信息
本文将通过MethodChannel获取设备信息,以此来演练MethodChannel用法。 建立channel flutter代码: MethodChannel methodChannel MethodChannel("com.xmg.test"); ohos代码: private channel: MethodChannel | null nullthis.c…...
深入HAL库:拆解STM32的UART DMA空闲中断接收机制,如何自己实现双缓冲与数据帧管理
STM32 HAL库UART DMA双缓冲机制深度解析与实战优化 在嵌入式开发领域,高效可靠的串口通信是实现设备间数据交互的基础能力。面对实时性要求严苛的工业场景或需要处理大量不定长数据的物联网应用,传统的轮询或中断接收方式往往力不从心。本文将深入剖析ST…...
视频下载高效获取:3个维度重新定义开源工具的使用体验
视频下载高效获取:3个维度重新定义开源工具的使用体验 【免费下载链接】downkyi 哔哩下载姬downkyi,哔哩哔哩网站视频下载工具,支持批量下载,支持8K、HDR、杜比视界,提供工具箱(音视频提取、去水印等&#…...
ThingsIoT Arduino客户端库:嵌入式设备云接入实战指南
1. ThingsIoT Arduino客户端库深度解析:面向嵌入式工程师的云平台接入实践指南1.1 库定位与工程价值ThingsIoT Arduino Client Library 是一款专为Arduino IDE生态设计的轻量级物联网设备云接入中间件,其核心工程目标并非提供通用通信协议栈,…...
AI辅助数据库设计:让快马平台智能生成优化过的社区论坛系统数据架构
今天想和大家分享一个用AI辅助设计数据库的实践案例——社区论坛系统的数据架构设计。整个过程在InsCode(快马)平台上完成,体验非常流畅。 业务场景分析 社区论坛的核心是内容交互,需要支持用户发帖、互动和管理。通过AI分析,我们确定了几个关…...
别再混淆了!用Arduino实操演示ROM、RAM和FLASH的区别(附内存监控技巧)
别再混淆了!用Arduino实操演示ROM、RAM和FLASH的区别(附内存监控技巧) 在嵌入式开发领域,存储器类型的选择直接影响着程序性能和系统稳定性。许多初学者在面对ROM、RAM和FLASH时常常感到困惑——它们看起来都是"存储数据&quo…...
C++开发者必看:nlohmann::json实战避坑指南(含性能优化技巧)
C开发者必看:nlohmann::json实战避坑指南(含性能优化技巧) 如果你正在用C处理JSON数据,nlohmann::json库大概率已经出现在你的项目依赖中。这个被戏称为"现代C的瑞士军刀"的库,确实让JSON操作变得像std::vec…...
vLLM-v0.17.1精彩案例:Qwen2-72B 4-bit量化后精度保持98.6%
vLLM-v0.17.1精彩案例:Qwen2-72B 4-bit量化后精度保持98.6% 1. vLLM框架简介 vLLM是一个专注于大语言模型(LLM)推理和服务的高性能开源库。这个项目最初由加州大学伯克利分校的天空计算实验室开发,现在已经发展成为一个活跃的社区驱动项目,…...
DataHub GraphQL API终极指南:30分钟掌握现代数据栈的元数据查询神器
DataHub GraphQL API终极指南:30分钟掌握现代数据栈的元数据查询神器 【免费下载链接】datahub The Metadata Platform for the Modern Data Stack 项目地址: https://gitcode.com/GitHub_Trending/da/datahub 你是不是经常为数据资产的管理而头疼࿱…...
Soop直播录制卡顿问题深度优化指南:从诊断到解决方案
Soop直播录制卡顿问题深度优化指南:从诊断到解决方案 【免费下载链接】DouyinLiveRecorder 项目地址: https://gitcode.com/gh_mirrors/do/DouyinLiveRecorder 一、问题诊断:直播录制卡顿的多维度分析 1.1 用户场景画像 不同用户群体面临的录制…...
X265墒编码--代码分析
x265 墒编码 X265 HEVC编码器架构分析 一 整体代码架构 1.1 目录与模块划分 source/ ├── x265cli.cpp / x265cli.h # 命令行入口、参数解析、help ├── x265.h # 对外 API、参数结构、版本 ├── encoder/ # 编码核心…...
