位置: 编程技术 - 正文

MySQL中的事件调度基础学习教程(mysql中事件的作用)

编辑:rootadmin

推荐整理分享MySQL中的事件调度基础学习教程(mysql中事件的作用),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql数据库事件,mysql数据库事件,mysql事件调用存储过程,mysql 事件,mysql数据库事件,mysql数据库事件,mysql中事件的作用,mysql事件使用方法,内容如对您有帮助,希望把文章链接给更多的朋友!

经常需要有一些定时任务在MySQL表上执行,例如统计、迁移、删除无用数据等。之前的作法是利用Linux cron定时运行脚本,但是发现这样的额外依赖有时并不方便,例如单机多实例部署时,就需要分别手动分别配置不同的cron任务,需要额外配置相应的用户和权限;新环境部署时容易遗漏cron任务等。

MySQL提供了Event Scheduler,与Linux下的crontab类似,可以根据时间调度来运行任务,运行一次或多次。

完整的Event Schduler创建语句如下:

一、调度SchedulerMySQL中的调度可以是只运行一次,也可以指定时间间隔重复运行。其定义是在event定义的ON SCHEDULE子句中。该子句格式如下:

其中,timestamp必须包括”年月日时分秒“,它参与表达式计算后,结果是datetime或者timestamp类型。

而时间间隔interval可以如下:

其含义很清晰,如YEAR 年;QUARTER 季度;YEAR_MONTH 年+月;MINUTE_SECOND 分钟+秒。

补充:

YEAR | QUARTER | MONTH | YEAR_MONTH 后台都转换成MONTH,其他时间间隔都转换成SECONDON SCHEDULE中的时间使用创建时本会话中的时区信息time_zone,这个时区默认是服务端的全局time_zone,也可能后续手动更新掉。这些时间会转化成UTC时间,存储到mysql.event表中。1.一次运行AT直接指定时间,或者使用时间表达式计算得出确定的时间点。

示例:

AT '-- ::′ 指定确切运行时间,本地时区。AT current_timestamp + INTERVAL '1:′ MINUTE_SECOND 指定1分秒后运行。2.多次运行EVERY设置运行的时间间隔,这里不能再指定[+ INTERVAL interval]。

指定STARTS、ENDS是可选的。

STARTS是指定重复运行的第一次是什么时候。不指定的情况下,会在事件创建时运行第一次,即等价于STARTS CURRENT_TIMESTAMP!ENDS告知MySQL结束重复运行的时间点。不指定的情况下,MySQL会永远重复运行下去。示例:

EVERY 5 WEEK 每5周运行一次,创建时运行第一次。EVERY 3 DAY STARTS '--4 ::′ 从'--4 ::′开始运行第一次,每隔3天运行一次。EVERY 2 MONTH STARTS CURRENT_TIMESTAMP + INTERVAL MINUTE ENDS '-- ::′ 分钟后开始到年底,每两个月运行一次。二、事件Event1.启用Event Scheduler功能Event是由一个特定的Event Scheduler线程执行的,运行过程中可以通过show full processlist查看其当前状态信息,如:

event_scheduler localhost [NULL] Daemon 3 Waiting on empty queue [NULL]

默认事件调度Event Scheduler功能是未启用的,需要配置全局参数event_scheduler,本参数可以动态设置,即时生效。

event_scheduler有如下三种取值:

OFF/0 关闭,默认值。不运行Event Scheduler线程,也就无法进行事件调度。设置为ON可以立即启用。ON/1 启用。DISABLED 禁用。同样不运行Event Scheduler线程。只有在MySQL服务启动时设置才有用。当event_scheduler是ON或者OFF时,不能在运行时设置event_scheduler为DISABLED。如果启动时配置了event-scheduler=DISABLED,则运行时就不能设置为ON/OFF。换句话中,可以在MySQL服务启动时设置为DISABLED,然后完全禁用了event_scheduler,不能动态调整。所以,要启用event_scheduler,运行时执行:

要随MySQL服务一起启用,则在/etc/my.cnf中添加

MySQL中的事件调度基础学习教程(mysql中事件的作用)

2.创建事件的语法

参数详细说明:DEFINER: 定义事件执行的时候检查权限的用户。ON SCHEDULE schedule: 定义执行的时间和时间间隔。ON COMPLETION [NOT] PRESERVE: 定义事件是一次执行还是永久执行,默认为一次执行,即NOT PRESERVE。ENABLE | DISABLE | DISABLE ON SLAVE: 定义事件创建以后是开启还是关闭,以及在从上关闭。如果是从服务器自动同步主上的创建事件的语句的话,会自动加上DISABLE ON SLAVE。COMMENT 'comment': 定义事件的注释。 3.更改事件的语法

4.删除事件的语法

5.Do子句在Do子句中实现事件的具体逻辑,几乎所有可以在存储程序中运行的MySQL语句都可以在event中使用。

1)简单SQL示例:

2)复杂SQL示例:

3)Do子句中SQL的限制

基本上Do中可以使用任何在存储程序(Stored Routine)中允许的SQL语句,而存储程序中有些限制,event还有些额外的限制。

Stored Routine中如下语句不允许:

LOCK TABLES/UNLOCK TABLES LOAD DATA与LOAD TABLE

支持动态SQL(PREPARE, EXECUTE, DEAALOCATE PREPARE)!但是PREPARE本身有些语句不允许执行。

INSERT DELAYED不会生效EVENT的限制:

如果Do子句中包含ALTER EVENT子句,虽然能够创建,但是运行时会出错。不要在Do子句中使用SELECT或SHOW这样仅仅是查询的语句,因为其输出无法从外部获取到。可以使用SELECT … INTO 这样的形式将查询结果保存起来。

5.查看EVENT有如下方式可以查看event的信息:

三、event schedule其他注意点MySQL保存了事件创建时的sql_mode作为其运行时的sql_mode;如果在一个调度区间内任务没有处理完成,新的调度依然会生成,这样就会出现同时又多个任务在运行的情况。如果要避免多个任务同时存在,可以使用GET_LOCK()函数或者行锁、表锁。

四、 Mysql事件实战测试环境创建一个用于测试的test表:

实战1Ø 创建一个每隔3秒往test表中插入一条数据的事件,代码如下:

Ø 创建一个分钟后清空test表数据的事件

Ø 创建一个在-- ::时刻清空test表数据的事件,代码如下:

Ø 创建一个从年8月日点分开始到分钟后结束,运行每隔3秒往test表中插入一条数据的事件,代码如下:

实战2通常的应用场景是通过事件来定期的调用存储过程,下面是一个简单的示例:创建一个让test表的id2字段每行加基数2的存储过程,存储过程代码如下:

事件设置-- ::时刻开始运行,每隔1调用一次存储过程,天后结束,代码如下:

MySQL的子查询及相关优化学习教程 一、子查询1、where型子查询(把内层查询结果当作外层查询的比较条件)#不用orderby来查询最新的商品selectgoods_id,goods_namefromgoodswheregoods_id=(selectmax(goods_i

Yii 连接、修改 MySQL 数据库及phpunit 测试连接 database1.修改protected/config/main.php去掉mysql数据库连接方式的注释,并且修改用户名,密码以及连接的数据库。2.新建protected/tests/unit/DbTest.php内容如下:phpc

MySQL中主键索引与聚焦索引之概念的学习教程 主键索引主键索引,简称主键,原文是PRIMARYKEY,由一个或多个列组成,用于唯一性标识数据表中的某一条记录。一个表可以没有主键,但最多只能有一

标签: mysql中事件的作用

本文链接地址:https://www.jiuchutong.com/biancheng/312350.html 转载请保留说明!

上一篇:安全地关闭MySQL服务的教程(如何关闭mysqld)

下一篇:MySQL的子查询及相关优化学习教程(mysql 子查询)

  • 发票冲红重开,重开时是按新税率还是旧税率
  • 增值税税率
  • 税务师2022年考试成绩
  • 超过库存现金限额的现金要及时存入银行
  • 银行的电子退库是什么,怎么做账
  • 预付装修费的会计分录
  • 处置使用过的固定资产,税率按多少
  • 企业收回以前注销时的坏账准备余额怎么处理?
  • 结转损益主营业务成本在借方还是贷方
  • 利润表的企业所得税怎么查询
  • 所有者权益变动表
  • 印花税零申报怎么填样本
  • 金税四期什么时候结束
  • 小微企业季度销售额超过30万增值税
  • 对公账号钱怎么拿出来
  • 公司设备没开票维修时配件能开票吗?
  • 委托出口业务的账务如何处理呢?
  • 维修材料费主要包括
  • 以固定资产投资入股
  • 工程施工怎么结转到成本里
  • 增值税年末结转是结转全年吗
  • 固定资产折旧方法的选择
  • 所得税到底按会计分录吗
  • win10待机唤醒黑屏死机
  • 公司的劳务费支出怎么做账
  • 即期结售汇期限包括
  • scworker.exe是病毒
  • 担保费可以计入什么科目
  • wordpress文章编辑
  • 正爬上唐娜·诺克沙滩的灰海豹,英格兰北林肯郡 (© Frederic Desmette/Minden Pictures)
  • vue-nginx刷新404问题
  • 递延所得税资产和所得税费用的关系
  • Mybatis+Servlet+Mysql 整合的一个小项目:对初学者非常友好,有助于初学者很快的上手Java Web
  • xa 事务
  • 印花税每个月都报吗
  • 一般纳税人购进免税农产品如何抵扣进项税额
  • 国外购买土地
  • 抵扣是什么意思大白话...举例
  • 企业所得税的纳税调整项和比例
  • CentOS 7.3上SQL Server vNext CTP 1.2安装教程
  • 预缴了增值税在申报增值税时申报
  • 会计中级工作年限截止日期
  • 购买商品的会计科目
  • 做账是指做什么
  • 税控系统技术维护费税率
  • 冲减以前年度利润
  • 房屋租赁费怎么记账
  • 未使用固定资产有哪些
  • 汇算清缴所得税的账务处理会计分录
  • 报销单可以当记账凭证吗
  • 进项发票可以退税吗
  • 可持续增长率和内部增长率的区别
  • mysql优化的几种方法
  • pc版直通车
  • windows2008教程
  • win10无人值守文件使用方法
  • 如何设置windows自动关机
  • ubuntu安装chia
  • linux nfs默认服务端口
  • winxp win10哪个快
  • 进程管理器命令
  • Linux怎么在家目录创建目录
  • win8鼠标右键无法弹出菜单
  • cocos creator截图
  • cocos2d
  • 遮罩层出现后怎么点击其他地方隐藏
  • 适配器模型
  • node.js gui
  • 批处理命令不允许用户在文件夹内的文件
  • python利用matplotlib将扇形平分成50份
  • Android Build.prop
  • shell脚本计算执行时间
  • 详细解读了
  • javascript入门教学
  • 税票上的开票员是谁
  • 社保批扣和灵活就业批扣有什么区别
  • 四川十大纳税企业
  • 国家税务局扬州 袁霞
  • 计算本月应交消费税分录
  • 建筑企业所交的税项有多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设