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

news2025/1/11 23:43:17

 事件由一个特定的线程——事件调度器来管理,事件是根据指定时间表,在某一特定的时间点,触发相关的SQL语句或存储过程。

01、事件概述

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

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

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

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

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

1. 查看事件调度器

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

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

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

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

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

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

03、创建事件

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

其中:

语法说明如下。

  • 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),并验证事件执行的结果。

以root@localhost这个用户的身份创建一次性定时器,执行时间为2021-08-19 21:30:00,当这个事件不会再发生时会被删除,该事件创建后为开启状态。查询结果存在一条记录,说明事件创建成功。

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

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

■ 图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表,以验证事件是否成功执行。

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

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

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

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

04、事件管理

1. 查看事件

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

 语法说明如下。

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

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

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

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

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

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

语法说明如下。

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

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

提示

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

 

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

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

2. 修改事件

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

语法说明如下。

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

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

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

3. 禁用事件

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

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

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

4. 启用事件

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

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

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

5. 删除事件

不再使用的事件可以删除,删除事件的基本语法格式如下所示。

语法说明如下。

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

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

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

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/75093.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

抓包分析ssh远程主机为何变慢了?

文章目录背景SSH协议握手过程ssh 抓包MAC层包传输tcp握手抓包解释三次握手的第一个报文- SYN包第一个报文对应的抓包详情三次握手的第二个报文- SYNACK包第二个报文对应的抓包详情三次握手的第三个报文- ACK包第三个报文对应的抓包详情ssh版本协议交换密钥协商key阶段Key Excha…

程序员的工资这么高,为什么还会有人离职?

出了社会以后才发现,班级里天天打鸡血的、最奋斗的、同时也最焦虑的,不是成绩最好的,也不是成绩最差的,而是那帮处于中间的人。 他们不像那些成绩最差的,或是天天摆烂,或是靠高情商混得风生水起&#xff1b…

Pytest----pluggy源码解读基础准备

【原文链接】Pytest----pluggy源码解读基础准备 解读pluggy源码,直接使用pytest环境中安装的pluggy即可,比如这里安装的pluggy版本是1.0.0,为了更好的理解源码,这里首先使用如下应用代码作为应用实例,从如下代码中可以…

低代码助力生产管理:离散型制造业MES系统

制造业作为我国国民经济的支柱产业,在我国经济增长中占有主导作用。而制造业对经济增长的贡献很大一部分来自于以离散制造业为代表的机械装备制造、汽车零部件制造等。因此,离散制造业的发展对我国经济增长具有举足轻重的作用。 离散型制造业的特点&…

中创股份在科创板提交上会稿:计划募资6亿元,景新海为董事长

12月8日,山东中创软件商用中间件股份有限公司(下称“中创股份”)在上海证券交易所科创板提交招股书(上会稿)。相较于此前招股书,中创股份补充了截至2022年9月30日的财务数据等信息。 据贝多财经了解&#x…

记一次 Eclipse 打包的辛酸历程

文章目录1:背景2 maven 工程3 普通工程3.1 打可执行的 jar3.2 打普通 jar4: 运行 jar 包1:背景 偶然的境况下,被迫使用了 Eclipse 进行代码。遇到的代码也有点奇怪,main 方法启动 java 工程,里面封装 Tomc…

音频声音信号

音频信号是模拟信号,我们需要将其保存为数字信号,才能对语音进行算法操作,WAV是Microsoft开发的一种声音文件格式,通常被用来保存未压缩的声音数据。 通道数:同时有个几个设备在进行音频的采样;采样频率&a…

Django连接MySQL与正反向迁移命令

目录 连接MySQL 方法一:pymysql连接 方法二:mysqlclient 迁移命令 连接MySQL 方法一:pymysql连接 第一步:修改settings.py配置文件中的DATABASES: DATABASES {default: {ENGINE: django.db.backends.mysql,HOS…

【车载开发系列】UDS诊断---动态定义DID($0x2C)

【车载开发系列】UDS诊断—动态定义DID($0x2C) UDS诊断---动态定义DID($0x2C)【车载开发系列】UDS诊断---动态定义DID($0x2C)一.概念定义1)DID定义方式2)DID失效条件二.应用场景三.报…

【Python游戏】今天小编用Python实现了一个植物大战僵尸小游戏 | 附源码

前言 halo,包子们下午好 今天给打击整一个植物大战僵尸 无广告版本 哈哈 说实话,现在的小游戏很多都是有广告,多少有点难受 今天给大家直接安排 相关文件 关注小编,私信小编领取哟! 当然别忘了一件三连哟~~ 源码点…

java基于Springboot的社区维修平台-计算机毕业设计

项目介绍 系统管理也都将通过计算机进行整体智能化操作,对于社区维修平台所牵扯的管理及数据保存都是非常多的,例如住户管理、社区公告管理、维修工管理、维修订单管理、接单信息管理、订单信息管理、在线沟通管理、举报信息管理、留言板管理、系统管理…

4G远程智能巡检摄像机功耗测试对比

对于一款输电线路监控设备,由于装在铁塔上面,对于功耗,电网上面的应用,尤为重要,如何得做到低功耗,一直大家研究的地方,解决了功耗,基本产品成功了一半,而合方圆在电网行…

对称加密算法(一)(替换算法,Caesar, Playfair, Hill Cipher,Polyalphabetic Cipher)

文章目录Symmetric Cipher ModelSubstitution TechniquesCaesar CipherMonoalphabetic CiphersPlayfair CipherHill CipherPolyalphabetic CipherVigenere CipherVernam CipherOne-Time PadReferences对称加密,也被称为传统加密、单钥加密或私钥加密,是 …

Flink系列-1、流式计算简介

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 大数据系列文章目录 官方网址:https://flink.apache.org/ 学习资料:https://flink-learning.org.cn/ 目录数据的时效性…

【pytorch】使用pytorch自己实现LayerNorm

pytorch中使用LayerNorm的两种方式,一个是nn.LayerNorm,另外一个是nn.functional.layer_norm 1. 计算方式 根据官方网站上的介绍,LayerNorm计算公式如下。 公式其实也同BatchNorm,只是计算的维度不同。 下面通过实例来走一遍公式 假设有如下的数据 …

JQuery 高级

目录 1. 动画 1. 三种方式显示和隐藏元素 1. 默认显示和隐藏方式 2. 滑动显示和隐藏方式 2. 遍历 1. js的遍历方式 2. jq的遍历方式 5. 插件:增强JQuery的功能 1 . 实现方式: 1. $.fn.extend(object) * 增强通过Jquery获取的对象的…

java计算机毕业设计ssm学生宿舍管理系统efyug(附源码、数据库)

java计算机毕业设计ssm学生宿舍管理系统efyug(附源码、数据库) 项目运行 环境配置: Jdk1.8 Tomcat8.5 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff0…

取余,模运算,余数的正负问题,1497. 检查数组对是否可以被 k 整除

首先,我们来看数学中对余数的定义 0到除数之间的整数,所以当除数是负数的时候,余数也是负数。 举个例子: 接下来,我们看计算机中余数是怎么求的??? 所有的语言和计算器都遵循了让商…

防火墙豁免实验

♥️作者:小刘在C站 ♥️每天分享云计算网络运维课堂笔记,疫情之下,你我素未谋面,但你一定要平平安安,一 起努力,共赴美好人生! ♥️夕阳下,是最美的,绽放,愿…

单商户商城系统功能拆解44—应用中心—小程序直播

单商户商城系统,也称为B2C自营电商模式单店商城系统。可以快速帮助个人、机构和企业搭建自己的私域交易线上商城。 单商户商城系统完美契合私域流量变现闭环交易使用。通常拥有丰富的营销玩法,例如拼团,秒杀,砍价,包邮…