MYSQL 定时自动执行任务

640?wx_fmt=png

MYSQL5.1开始支持EVENT功能,类似Oracle和MSSQL的定时任务job功能。有了这个功能之后我们就可以让MySQL自动的执行存储过程来实现数据汇总等功能了,不用像以前哪样手动操作完成了。下面我们来测试下,在MYSQL中如何自动执行指定存储过程,实现相关功能。

一、创建测试表
CREATE TABLE EVENT_table(
id INT auto_increment PRIMARY KEY NOT NULL,
conent VARCHAR(80)
)ENGINE=INNODB DEFAULT CHARSET=utf8;

二、创建调用存储过程
DROP PROCEDURE IF EXISTS pr_event;
CREATE PROCEDURE pr_event(
)
proc_start:BEGIN

INSERT INTO  EVENT_table(conent) VALUES ('520');

END proc_start

三、创建事件调用存储过程

创建事件语法:

CREATE EVENT [IF NOT EXISTS] event_name
ON SCHEDULE SCHEDULE
[ON COMPLETION [NOT] PRESERVE]
[ENABLE | DISABLE]
[COMMENT 'comment']
DO sql_statement;
要使定时事件起作用,MySQL的常量GLOBAL event_scheduler必须为on或者是1。
1、查看scheduler的当前状态:
a、SHOW VARIABLES LIKE 'event_scheduler';
b、SELECT @@event_scheduler;

2、修改scheduler状态为打开(0:off  ,  1:on):
SHOW VARIABLES LIKE 'event_scheduler';-- 查看是否开启定时器(OFF:关闭,ON:开启)

打开定时器(四种方式):

a、SET GLOBAL event_scheduler=ON;
b、SET @@global.EVENT_scheduler=ON;
c、SET GLOBAL event_scheduler=1;
d、SET @@global.event_scheduler=1;

3、创建事件,设置每10分钟执行一次(调用pr_event存储过程)。
CREATE EVENT IF NOT EXISTS ent_test
ON SCHEDULE EVERY 10 MINUTE
-- ON COMPLETION PRESERVE      -- 当EVENT到期时,EVENT会被disable,但是该EVENT还是会存在
-- ON COMPLETION NOT PRESERVE  -- 当EVENT到期时,该EVENT会被自动删掉,该项为默认值
DO CALL pr_event(); -- pr_event()为需要定时处理的存储过程,这里也可以改成相关SQL可执行语句

4、开启事件
ALTER EVENT ent_test ENABLE;

5、临时关闭事件
ALTER EVENT ent_test DISABLE;

6、重命名事件并加上备注
ALTER EVENT test.ent_test RENAME TO ent_test_new COMMENT '重命名事件ent_test';

7、删除事件

DROP EVENT IF EXISTS ent_test;

8、查看指定事件的详细信息

SELECT * FROM information_schema.EVENTS WHERE event_name='ent_test';

SELECT * FROM information_schema.EVENTS WHERE event_name LIKE CONCAT('%','ent_test','%');

9、查看事件的创建SQL语句

SHOW CREATE EVENT ent_test;


四、一些典型应用示例:

1、从现在开始每隔九天定时执行

  CREATE EVENT EVENT1

  ON SCHEDULE EVERY 9 DAY STARTS NOW()

  ON COMPLETION PRESERVE ENABLE

  DO

  BEGIN

  CALL TOTAL();

  END

2、每个月的一号凌晨1 点执行

  CREATE EVENT EVENT2

  ON SCHEDULE EVERY 1 MONTH STARTS DATE_ADD(DATE_ADD(DATE_SUB(CURDATE(),INTERVAL DAY(CURDATE())-1 DAY), INTERVAL 1 MONTH),INTERVAL 1 HOUR)

  ON COMPLETION PRESERVE ENABLE

  DO

  BEGIN

  CALL STAT();

  END

3、每个季度一号的凌晨2点执行

  CREATE EVENT TOTAL_SEASON_EVENT

  ON SCHEDULE EVERY 1 QUARTER STARTS DATE_ADD(DATE_ADD(DATE( CONCAT(YEAR(CURDATE()),'-',ELT(QUARTER(CURDATE()),1,4,7,10),'-',1)),INTERVAL 1 QUARTER),INTERVAL 2 HOUR)

  ON COMPLETION PRESERVE ENABLE

  DO

  BEGIN

  CALL SEASON_STAT();

  END

4、每年1月1号凌晨四点执行

  CREATE EVENT TOTAL_YEAR_EVENT

  ON SCHEDULE EVERY 1 YEAR STARTS DATE_ADD(DATE(CONCAT(YEAR(CURDATE()) + 1,'-',1,'-',1)),INTERVAL 4 HOUR)

  ON COMPLETION PRESERVE ENABLE

  DO

  BEGIN

  CALL YEAR_STAT();

  END

  MySQL的event和Oralce的Job还是有点不同的,这点让笔者比较困扰

5、在进行按月,季,年进行自动调用存储过程时,为了测试可以把系统改为年的最后一天,如2010-12-31 23:59:55;

  这个Oracle的Job就会把月,季,年存储过程执行一遍。但MySQL改了系统时间了Event也没有定时执行。不知道各位大虾有没有什么好办法?可以解决这个问题。

 五、查看事件运行基本信息

SELECT * FROM information_schema.events ORDER BY last_executed DESC

SELECT * FROM mysql.event ORDER BY last_executed DESC

SHOW EVENTS

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

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

相关文章

docker删除本地已下载的镜像

1:首先用 docker images 查看一下本地已下载的镜像 2:使用 docker rmi --force IMAGED ID 删除镜像

51单片机独立键盘和矩阵键盘

独立键盘代码&#xff1a; #include<reg52.h> #include<intrins.h>#define uint unsigned int #define uchar unsigned charsbit beepP2^3; sbit DUAN P2^6;//数码管段选 sbit WEIP2^7; //数码管位选sbit key_s2 P3^0;//独立按键s2 sbit key_s3 P3^1;//独立按键s3…

SQLSERVER数据库内存占用高的解决方法

远程登录服务器时发现程序执行时特别卡&#xff0c;利用任务管理器查看了下系统资源使用情况&#xff0c;监视一段时间后发现CPU占用不大&#xff0c;但是内存占用量居高不下&#xff0c;然后发现是Sqlserver.exe这个服务占用内存很大&#xff0c;达到了近2G服务器配置的8G内存…

docker ps 和docker ps -a

列出正在运行的容器 docker ps 显示所有的容器&#xff0c;包括未运行的 docker ps -a

51单片机8*8点阵屏、取模软件的使用

取模软件网盘提取 链接&#xff1a;https://pan.baidu.com/s/1YYQo_tZNCXlo9uWVbtsNdg 提取码&#xff1a;jfbr 74HC595芯片原理图&#xff1a; 两片595芯片级联驱动点阵屏只需要三个IO口&#xff0c;串行入&#xff08;一次只能传一个数据&#xff0c;S_CLK&#xff09;并行…

(Object-C)学习笔记(一)--开发环境配置和与c语言的区别

博主是大三快要实习的学生&#xff0c;作为软件技术专业的我认真的考虑了一下出路&#xff0c;认为去干起点低低java不如花点钱选择iOS。正好我也对iOS很感兴趣&#xff0c;虽然我赶不上08年之后的那一段互联网热潮&#xff0c;但是这一段时间互联网仍旧稳步发展&#xff0c;而…

MVC下实现LayUI分页的Demo

1、后台获取数据示例public JsonResult GetPageNew(int page,int pagesize){var list _context.ArticleInfo.Skip(page).Take(pagesize).ToList();return Json(new { data list, total list.Count });}2、View视图<head><meta charset"UTF-8"><tit…

使用docker安装elasticsearch

下载elasticsearch6.4.0的docker镜像: docker pull elasticsearch:6.4.0 修改虚拟内存区域大小&#xff0c;否则会因为过小而无法启动: sysctl -w vm.max_map_count262144 使用docker命令启动 docker run -p 9200:9200 -p 9300:9300 --name elasticsearch \ -e "discov…

中断系统详解、外部中断

51单片机各个引脚功能 IO口引脚&#xff1a; 中断系统的主要功能&#xff1a;处理随机突发事件 中断系统结构&#xff1a; 什么是中断系统&#xff1a; 数据的输入/输出传送方式&#xff1a; 中断传送方式特点&#xff1a; 51系统允许的5个中断源&#xff1a; 51单片…

android app两种调试方法

方法一&#xff1a; 1、使用apktool的-d选项反编译apk文件 java -jar apktool.jar d -d target.apk -o output 2、在AndroidManifest的application节点中添加 android:debuggable"true" 3、在入口点的类的onCreate中添加如下代码等待调试 invoke-static{}, La…

2019温馨的元旦祝福语 2019元旦祝福语大全!收藏备用!

打开日历新日子&#xff0c;2019年展开新篇子&#xff0c;送你祝福金盒子&#xff0c;包含吉祥话段子&#xff0c;金银财宝满屋子&#xff0c;升官发财有路子&#xff0c;聪明赛过孙猴子&#xff0c;拥有致富鬼点子&#xff0c;娶妻生子抱孩子&#xff0c;没事天天找乐子&#…

定时/计数器(定时和计数的功能)、定时器中断

定时/计数器实现功能&#xff1a; &#xff08;1&#xff09;定时功能&#xff1a; 定时/计数器说明&#xff08;最高单次计时时间是71毫秒65535*1.085us&#xff0c;1.085us是机器周期&#xff09;&#xff1a; 使用51定时/计数器步骤: 定时/计算器控制寄存器&#xff1a;…

jquery.cookie中的操作之与换肤

jquery.cookie.js的插件&#xff0c;插件的源代码如下&#xff1a; /*** Cookie plugin** Copyright (c) 2006 Klaus Hartl (stilbuero.de)* Dual licensed under the MIT and GPL licenses:* http://www.opensource.org/licenses/mit-license.php* http://www.gnu.org/license…

51单片机—串口通信

计算机串行通信&#xff1a; 并行通信&#xff1a; 串行通信&#xff1a; 异步通信&#xff1a; 同步通信&#xff1a; 串行通信的传输方向&#xff1a; 串行通信常见的错误校验&#xff1a; 传输速率比特率&#xff08;波特率&#xff09;&#xff1a; &#xff08;fos…

IIC总线通讯协议、EEPROM芯片

EEPROM芯片&#xff1a; 掉电不会丢失数据&#xff0c;可以保存数据。 IIC串行总线的组成及工作原理&#xff1a; IIC总线传输协议 IIC产生起始与终止信号&#xff1a; IIC字节的传送与应答&#xff1a; 应答位作用&#xff1a; 数据帧格式&#xff1a; 总线寻址 软件模…

【Xamarin挖墙脚系列:最重要的布局ListView】

安卓的几个重要的布局 线性布局 相对布局 Table布局 Tab布局 表格Grid布局 列表布局。 这几种基本的布局的方式&#xff0c;最重要的是列表布局。任何一个程序&#xff0c;基本都可以划分为 3点一线模式&#xff08;类别 列表 详细&#xff09;&#xff0c;我个人称呼它为CLD…

STM32F1 GPIO工作原理初探

GPIO工作方式&#xff1a; 1、四种输入模式 输入浮空 输入上拉 输入下拉 模拟输入 2、四种输出模式 开漏输出&#xff1a; 只可以输出强低电平&#xff0c;高电平得靠外部电阻拉高。输出端相当于三极管的集电极&#xff0c;要得到高电平状态需要上拉电阻才行&#xff0…

STM32F103ZET6 点灯的三种操作方式(库函数、寄存器、位操作)

LED硬件连接&#xff1a; 点灯的基本步骤&#xff1a; 库函数版本 重要函数&#xff1a; main.c部分&#xff1a; #include "stm32f10x.h" #include "LED.h" #include "delay.h"int main(void) {LED_Init();//GPIOB、E初始化delay_init()…

redis的分布式解决方式--codis

codis是豌豆荚开源的分布式server。眼下处于稳定阶段。 原文地址&#xff1a;https://github.com/wandoulabs/codis/blob/master/doc/tutorial_zh.md Codis 是一个分布式 Redis 解决方式, 对于上层的应用来说, 连接到 Codis Proxy 和连接原生的 Redis Server 没有明显的差别 (不…

STM32F103ZET6 蜂鸣器、按键

蜂鸣器的硬件电路&#xff1a; 蜂鸣器实验步骤&#xff1a; 实验步骤基本和跑马灯一样&#xff0c;代码和跑马灯也基本一样&#xff0c;只是用的GPIO不同。 几种输入输出模式&#xff1a; beep.c部分代码&#xff1a; #include "beep.h" #include "stm32f1…