news 2026/4/15 10:51:41

Mysql中event用法详解,零基础快速入门必看!

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Mysql中event用法详解,零基础快速入门必看!

Event即事件,也是一种数据库对象,又叫时间触发器或者事件调度器,与triggers的事件触发不同,tiggers会因为update、delete、insert等事件触发,而event类似与linux crontab计划任务,用于时间触发,当到了设定执行时间时,系统会触发相关的SQL语句或存储过程,相当于我们给存储过程创建了定时任务。

  • 适用范围:对于每隔一段时间就有固定需求的操作,如创建表,删除数据、插入数据,修改数据等操作,可以使用event来处理。

例如:在每月的1日凌晨1点自动创建下个月需要使用的三张表;在每月第一天时查询汇总上月商品的销售汇总信息,然后将这些信息插入到汇总信息表里。这些情况都可以使用event来处理。

一、Event创建语法

CREATE Event [IF NOT EXISTS] event_name -- 创建使用create event ON SCHEDULE schedule -- on schedule 什么时候来执行,执行频率 [ON COMPLETION [NOT] PRESERVE] -- 调度计划执行完成后是否还保留 [ENABLE | DISABLE] -- 是否开启事件,默认开启 [COMMENT 'comment'] -- 事件的注释 DO event_body; -- 这个调度计划要做什么?

创建语法中[]里的内容是可以省略的。

[IF NOT EXISTS]如果新建的event_name系统里不存在,则创建一个新的,如果已经存在了,则提示已经存在。如果省略的话,系统里不存在新的event_name则创建成功,如果已经存在了,会保存。

[ON COMPLETION [NOT] PRESERVE 如果带了not当事件执行完后,就自动删除,不保留事件。如果不加not事件执行完会保留下来,该项不写的时候,默认是执行完事件保留下来。

[ENABLE | DISABLE]ENABLE时事件开启,当到了事件执行时间,系统会自动执行event_body里定义的语句,如果设置的是DiSABLE则事件关闭,到了执行时间,事件也不会执行。该项没有设置时,默认为事件开启。

[COMMENT 'comment']comment是事件注释,对事件进行解释说明。

event_body事件主体,可以是单条DML语句,可以是多条DML语句,多条时需要写在begin……end之间,也可调用存储过程。

二、执行时间说明

1、单次计划:

  • 在2019年2月1日4点执行一次

  • on schedule at '2019-02-01 04:00:00’

2、重复计划

  • on schedule every 1 second 每秒执行一次

  • on schedule every 1 minute 每分钟执行一次

  • 也可以是hour、day、week、month、year

3、指定开始时间的重复计划

  • 每天在20:00:00执行一次

  • on schedule every 1 day starts ‘2021-6-16 20:00:00'

三、如何查看Event

查看有哪些event Show events; 或者通过Select * from information_schema.events; 查看event具体内容 SHOW CREATE EVENT event_name1; 删除event DROP EVENT event_name; 修改event 可以先删除,再重新创建 也可以ALTER EVENT event_name …… 省略号后边的内容和创建event一样

四、实例

先创建一个表student_bak,用此表来备份student表的数据;​​​​​​​

create table student_bak select * from student; 接着,我们创建存储过程student_bak_pro,用来备份student表中的最新数据 CREATE DEFINER=`root`@`localhost` PROCEDURE `student_bak_pro`() BEGIN insert into student_bak select * from student t where not EXISTS (select * from student_bak t1 where t1.sno=t.sno); COMMIT; END 然后,我们再创建event,让系统每3秒自动执行以下存储过程student_bak_pro CREATE Event student_bak_event ON SCHEDULE every 3 second ON COMPLETION PRESERVE DO call student_bak_pro();

最后,我们给student表新插入三条条数据,然后我们去观察student_bak表里数是不是也插入了最新的数据。​​​​​​​

INSERT INTO student VALUES (2008063, 'Penqun63', '男', 12, '2009-02-24', NULL),(2008064, 'Penqun63', '男', 12, '2009-02-24', NULL), (2008065, 'Penqun65', '男', 12, '2009-02-24', NULL);

本章主要讲解了关于“Mysql中event用法详解”的内容,大家觉得有用的话记得关注公众号哦。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 7:23:27

管理权限累到手抽筋,智慧园区多租户管理方案高效管理

在大型园区中,除了建设方自用空间,往往会将多余空间出租给其他企业,同一空间不同组织的复杂业态让管理复杂程度呈指数级增长。权责不清、数据不通、成本不降等问题,正不断消耗着园区管理方的精力,也影响着租户的体验感…

作者头像 李华
网站建设 2026/3/30 22:57:40

基于单片机的室内空气质量监控系统设计

2系统硬件设计 2.1 单片机的选择与设计 为了实现课题要求,需要选择一款最适合的单片机来作为主控制器。因为本设计中涉及到温湿度采集模块、甲醛采集模块、显示模块、按键模块、报警模块、加湿及风扇模块。其中,温湿度采集、甲醛采集和按键是输入&#x…

作者头像 李华
网站建设 2026/4/13 12:34:20

助力航空精密制造:Tube Qualify在管路在线检测与弯曲分析中的应用

航空管路系统(燃油、液压、气动)的复杂管路,往往带有法兰、接头等部件,具有数量多、形状多样、结构复杂等特点,是航空装备的关键部件之一。为保证设备的平稳运行,在装配时,对管路的尺寸精度要求…

作者头像 李华
网站建设 2026/4/13 16:11:42

一篇文章讲透网络协议知识体系:从TCP/IP、HTTP到NoSQL的协议栈全景

面试常用知识点总结 1. HTTP协议 HTTP请求和响应的组成部分 常见的HTTP方法及其用途 常见的HTTP状态码及其含义 HTTP/1.1和HTTP/2的主要区别 无状态协议的含义及其影响 2. TCP/IP协议栈 TCP/IP协议栈的四层结构及其功能 各层常见协议及其特点 TCP和UDP的区别 TCP三次握手和四次…

作者头像 李华
网站建设 2026/4/10 13:03:56

网络协议硬核解析:应对HTTP/TCP/UDP及NoSQL的灵魂拷问与设计原理

面试常用知识点总结 1. HTTP协议 HTTP请求和响应的组成部分 常见的HTTP方法及其用途 常见的HTTP状态码及其含义 HTTP/1.1和HTTP/2的主要区别 无状态协议的含义及其影响 2. TCP/IP协议栈 TCP/IP协议栈的四层结构及其功能 各层常见协议及其特点 TCP和UDP的区别 TCP三次握手和四次…

作者头像 李华