数据库原理及MySQL应用 | 事件

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: 事件由一个特定的线程——事件调度器来管理,事件是根据指定时间表,在某一特定的时间点,触发相关的SQL语句或存储过程。

5.jpeg

01、事件概述

事件(Event)是根据指定时间表执行的任务,是MySQL在相应的时刻调用的过程式数据库对象。它由事件调度器这一特定的线程来管理的。

事件调度器即定时任务调度器,指在某个特定的时间根据计划自动完成指定的任务或每隔多长时间根据计划做一次指定的任务。MySQL的事件调度器可以实现每秒执行一个任务,这在一些对实时性要求较高的环境下是非常实用的。

事件调度器是定时触发执行的,从这个角度上看也可以称其为“临时触发器”。但是它与触发器又有所区别,触发器只针对某张数据表产生的事件(INSERT、UPDATE和DELETE操作)执行特定的任务,而事件调度器则是根据时间周期来触发设定的任务,且操作对象可以是多张数据表。

02、开启或关闭事件调度器

由于事件是由事件调度器这一特定的线程来管理的,因此若想让事件正常执行,首先要开启事件调度器。MySQL 8.0以上是默认开启事件调度器的。

1. 查看事件调度器

可以通过对全局变量event_scheduler的查看,掌握事件调度器的状态,其值为OFF表示关闭,其值为ON表示开启。

查看事件调度器的基本语法格式如下所示。

image.png


三种方法执行后,显示方式稍有不同。

2. 开启或关闭事件调度器

开启事件调度器的基本语法格式如下所示。

image.png


关闭事件调度器的基本语法格式如下所示。

image.png

03、创建事件

MySQL事件信息保存在mysql.event表中,虽然可以直接操作该表,但是容易出现不可预知的错误,因此建议采用CREATE EVENT语句在指定的数据库下创建。创建事件的基本语法格式如下所示。
image.png
其中:

语法说明如下。

event_name是新建事件的名称,事件名称必须符合标识符命名规则,且名称必须唯一。新创建的事件默认属于当前数据库,若要在指定数据库中创建事件,创建时应将名称指定为db_name.event_name。

DEFINER=user是可选选项,用于定义事件创建者,省略表示当前用户。

IF NOT EXISTS是可选选项。添加该选项,表示指定的事件不存在时执行创建事件操作,否则忽略此操作。

ON SCHEDULE schedule表示触发点,用于定义执行的时间和时间间隔,包括2种选项:AT timestamp一般只执行一次,INTERVAL关键字可以用于计算时间间隔,可以直接与日期、时间进行计算;EVERY interval一般周期性执行,STARTS timestamp是可选项,用于设定开始时间,ENDS timestamp是可选选项,用于设定结束时间。

ON COMPLETION [NOT] PRESERVE是可选选项,用于定义事件执行完毕是否保留,默认为NOT PRESERVE不保留,即删除事件。

ENABLE | DISABLE | DISABLE ON SLAVE是可选选项,用于指定事件的属性,包括3种选项:ENABLE表示该事件创建以后是开启的,也就是系统将执行这个事件,为默认选项;DISABLE表示该事件创建以后是关闭的,也就是事件的声明存储到目录中,但是不执行这个事件;DISABLE ON SLAVE表示事件在从机中是关闭的。一般用不上,只有设置了MySQL主从数据库才会用得上,指该事件已在主服务器上创建并复制到从属服务器,但在从属服务器上是关闭的。

COMMENT 'comment'是可选选项,用于定义事件的注释。

DO event_body用于指定事件启动时所要执行的代码,可以是任何有效的SQL语句、存储过程或一个计划执行的事件。如果包含多条语句,可以使用BEGIN…END复合结构。

【例9-25】在图书销售数据库booksale中建立事件event_test1,该事件注释为一次性定时器,设定在2021-08-19 21:30:00将系统时间以字符串的形式插入已经存在的eventtest表中,该表的结构为(id,user, createtime),并验证事件执行的结果。
image.png
以root@localhost这个用户的身份创建一次性定时器,执行时间为2021-08-19 21:30:00,当这个事件不会再发生时会被删除,该事件创建后为开启状态。查询结果存在一条记录,说明事件创建成功。

在事件执行时间2021-08-19 21:30:00之后查看eventtest表,以验证事件是否成功执行。

image.png


执行结果如图1所示。再次查看事件。

image.png


image.png


■ 图9-7事件执行后

事件在设定的执行时间2021-08-19 21:30:00正确执行,并将执行时间插入指定的数据表eventtest中,该事件已经执行完毕,不会再次发生,按创建事件的参数,系统自动将事件删除,因此在查看事件时为空。

【例9-26】在图书销售数据库booksale中建立事件event_test2,该事件为重复性定时器,设定在2021-08-19 21:55:00到2021-08-19 22:00:00每隔1分钟,将系统时间以字符串的形式插入已经存在的eventtest表中,该表的结构为(id,user, createtime),并验证事件执行的结果。

以root@localhost这个用户的身份创建重复性定时器,执行时间为2021-08-19 21:55:00到2021-08-19 22:00:00,执行频率为每分钟一次,执行结束后应该多出6条数据。结束时间也可以不写,那就是从开始时间一直执行。当这个事件不会再发生时也不会被删除,该事件创建后为开启状态,事件结束后为关闭状态。查询结果存在一条记录,说明事件创建成功。

在事件执行结束时间2021-08-19 22:00:00之后查看eventtest表,以验证事件是否成功执行。

image.png


执行结果如图9-8所示。

【例9-27】在图书销售数据库booksale中建立事件event_test3,该事件为重复性定时器,从现在开始的一年内每天删除订单表orders中订购日期大于120天的订单,订单项目表orderitems中的相关联记录同步删除,并验证事件执行的结果。

image.png


事件执行前订单表orders和订单项目表orderitems中的记录如图9-9和图9-10所示。事件执行后订单表orders和订单项目表orderitems中的记录如图9-11和图9-12所示。

image.png


从执行结果可以看到,orders表中订购日期在120天前的记录被删除,同时被删除的订单对应的订单明细从orderitems表中被同步删除。该事件开始时间为创建事件之日起,结束时间为1年后,每天重复执行删除操作。

04、事件管理

1. 查看事件

查看事件的基本语法格式如下所示。

image.png


语法说明如下。

{FROM | IN} db_name是可选选项,用于指出要查看的数据库名,其中FROM | IN关键字可以省略。若未指出数据库,则获取当前选择的数据库。

LIKE 'pattern' | WHERE expr是可选选项。LIKE 'pattern'中pattern是匹配字符串,省略时表示查看所有事件,可使用LIKE结合通配符查看部分事件的值,也可直接写事件名;WHERE expr用于指定查看事件的条件。

【例9-27】查看图书销售数据库booksale中存在的所有事件。

image.png


event_test2事件已经结束,自动调整为关闭状态。event_test3事件还没有结束,仍为开启状态。

【例9-28】查看图书销售数据库booksale中开启的事件。

image.png


事件状态status的值有三种,ENABLED表示事件是开启的,DISABLE表示事件是关闭的,DISABLE ON SLAVE表示事件在从机中是关闭的。

image.png


语法说明如下。

在系统数据库information_schema中的EVENTS表中,可以通过SELECT语句查看事件的定义。

event_name= 'event_name'用于查找event_name列的值为event_name事件名的指定事件的信息。

提示

以上命令没有限定数据库,所以查看的是当前服务器中所有名为event_name的事件,要查看指定数据库,需要添加条件EVENT_SCHEMA=' db_name'。

【例9-29】查看图书销售数据库booksale中名为event_test3的事件。

image.png


在图形化界面中由于列宽问题显示不全,可在命令行状态输入该命令并将“;”替换成“\G”结尾,结果将以垂直方向显示。

2. 修改事件

修改事件可以更改现有事件的各种属性,修改事件的基本语法格式如下所示。

image.png


image.png


语法说明如下。

RENAME TO是重新为事件命名,new_event_name是新的事件名称。若使用db_name.event_name指定事件所属数据库,则是将事件从一个数据库移动到另一个数据库中。

除上面关键字外,其他关键字和参数同创建事件的语法保持一致。

【例9-30】修改图书销售数据库booksale中名为event_test3的事件,将其改名为event_delete,时间频率改为1周,结束时间改为半年。

image.png

3. 禁用事件

临时关闭事件被称为禁用事件,禁用事件的基本语法格式如下所示。

image.png


语法说明:event_name是禁用事件的名称。事件默认属于当前数据库,也可使用db_name.event_name禁用指定数据库中的事件。

【例9-31】修改图书销售数据库booksale中名为event_delete的事件,将其临时关闭。

image.png

4. 启用事件

将禁用事件重新启用被称为启用事件,启用事件的基本语法格式如下所示。

image.png


语法说明:event_name是启用事件的名称。事件默认属于当前数据库,也可使用db_name.event_name启用指定数据库中的事件。

【例9-32】启用图书销售数据库booksale中名为event_delete的事件。

image.png


语法说明如下。

event_name是删除事件的名称。默认删除的是当前数据库中的事件,也可使用db_name.event_name删除指定数据库中的事件。

IF EXISTS是可选选项。添加该选项,表示指定的事件存在时执行删除事件操作,否则忽略此操作。

【例9-33】删除图书销售数据库booksale中名为event_delete的事件。

image.png

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1天前
|
存储 算法 数据库
矢量数据库在图像识别与检索中的应用实践
【4月更文挑战第30天】本文探讨了矢量数据库在图像识别与检索中的应用,通过特征提取(如SIFT、SURF)、编码和相似度度量实现快速识别。在图像检索流程中,经过预处理、特征提取和编码后,矢量数据库用于查询相似特征,排序后展示给用户。实际案例显示,矢量数据库能提升电商平台的商品图像搜索效率和用户体验。随着技术发展,这一领域应用前景广阔。
|
1天前
|
机器学习/深度学习 搜索推荐 数据库
矢量数据库的未来发展趋势:新技术与应用展望
【4月更文挑战第30天】随着AI和机器学习的发展,矢量数据库在处理非结构化数据方面的重要性日益增强。预测到2028年,全球矢量数据库市场将从2023年的15亿美元增长至43亿美元。未来趋势包括:并行计算与分布式架构提升处理能力,硬件加速技术(如TPU和昇腾芯片)提高性能,自适应索引机制优化查询效率。应用领域将拓展至NLP、图像视频分析和推荐系统,为各行业带来更多创新和价值。
|
1天前
|
机器学习/深度学习 存储 人工智能
矢量数据库在机器学习领域的应用与前景
【4月更文挑战第30天】本文探讨了矢量数据库在机器学习领域的应用,包括特征存储、相似性搜索、模型训练与调优及实时分析。随着AI技术发展,矢量数据库将深度融合,提升扩展性和可伸缩性,增强智能化功能,并加强安全性与隐私保护。未来,矢量数据库将在机器学习领域扮演关键角色。
|
1天前
|
存储 数据可视化 关系型数据库
矢量数据库在地理空间数据处理中的应用
【4月更文挑战第30天】矢量数据库在地理空间数据处理中展现优势,高效存储管理高维向量数据,支持快速查询、空间分析与可视化。分布式处理能力适应大数据量需求,提供高效、灵活、可扩展及可视化支持,是处理地理空间数据的理想选择。随着技术进步,其应用将更加广泛。
|
1天前
|
SQL 关系型数据库 数据库
【MySQL】:DDL数据库定义与操作
【MySQL】:DDL数据库定义与操作
8 0
|
2天前
|
关系型数据库 MySQL 测试技术
【专栏】将 PostgreSQL 迁移到 MySQL 数据库
【4月更文挑战第29天】本文探讨了PostgreSQL数据库向MySQL迁移的过程、挑战及策略。迁移步骤包括评估规划、数据导出与转换、创建MySQL数据库、数据导入。挑战包括数据类型不匹配、函数和语法差异、数据完整性和性能问题。应对策略涉及数据类型映射、代码调整、数据校验和性能优化。迁移后需进行数据验证、性能测试和业务验证,确保顺利过渡。在数字化时代,掌握数据库迁移技能对技术人员至关重要。
|
2天前
|
运维 监控 关系型数据库
Serverless 应用引擎产品使用之在阿里云函数计算(FC)中,要访问另一个账号的rds配置rds的白名单如何解决
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
14 0
|
2天前
|
SQL 分布式计算 关系型数据库
云原生数据仓库产品使用合集之可以把ADB MySQL湖仓版数据库做成页面查询的数据库吗
阿里云AnalyticDB提供了全面的数据导入、查询分析、数据管理、运维监控等功能,并通过扩展功能支持与AI平台集成、跨地域复制与联邦查询等高级应用场景,为企业构建实时、高效、可扩展的数据仓库解决方案。以下是对AnalyticDB产品使用合集的概述,包括数据导入、查询分析、数据管理、运维监控、扩展功能等方面。
|
3天前
|
关系型数据库 MySQL 数据库
【MySQL探索之旅】数据库的基本操作
【MySQL探索之旅】数据库的基本操作
|
4天前
|
存储 关系型数据库 MySQL
【MySQL】数据库规范化的三大法则 — 一探范式设计原则
【MySQL】数据库规范化的三大法则 — 一探范式设计原则