Mysql中event事件的入门


主要涉及的知识点:mysql的存储过程、mysql的event事件调度。

参考资料:

Qiao_Zhi的博客:【周期性执行事件】MySQL事件(Event)&任务调度

起风了的博客:mysql存储过程查询结果循环遍历 判断 赋值 游标等基本操作

webbc的文章:MySQL游标概念与用法详解

莱克星顿的枪声的博客:mysql游标的用法及作用

阿凯--Nonkey的博客:MySql 游标的使用(二)FETCH INTO取出来的部分字段为NULL

qq564392180的博客:Mysql Event Scheduler不执行


直接示例:

假如要实现这样一个场景,购买订单生成后,三十分钟未支付,自动更新订单状态,并返还商品库存。

存储过程示例:

delimiter //
DROP PROCEDURE IF EXISTS `updateOrderStatus` //
CREATE PROCEDURE updateOrderStatus()
BEGIN
DECLARE order_id int DEFAULT 0;
DECLARE goods_id int DEFAULT 0;
DECLARE done int DEFAULT 0;
DECLARE overtime_order CURSOR FOR select id,shop_id from `order` where `status`='等待支付' and `order_time`<=(unix_timestamp(now())-1800);
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done=1;
OPEN overtime_order;
read_loop:LOOP
FETCH overtime_order into order_id,goods_id;
if done = 1 THEN
leave read_loop;
END IF;
update `order` set `status` = '未支付',order_end_time=now() where `id`=order_id;
update `shop` set `num` = `num`+1 where `id`=goods_id;
END LOOP;
CLOSE overtime_order;
END //
delimiter ;

event事件调度示例:

drop event if exists event_update_order;
CREATE event event_update_order
ON SCHEDULE EVERY 1 MINUTE
DO CALL updateOrderStatus();

知识点:

(1)修改sql默认的以【分号;】结束为【//】: delimiter //

(2) 创建存储过程前先查看下是否已存在:show create procedure updateOrderStatus;

  或存在先删除:DROP PROCEDURE IF EXISTS `updateOrderStatus`;

(3)创建event事件前先查看下是否已存在:show create event event_update_order;

  或存在先删除:drop event if exists event_update_order;

(4)mysql的event事件调度程序默认是关闭的。

  查看event是否开启:
mysql> SHOW VARIABLES LIKE 'event_scheduler';
+-----------------+-------+
| Variable_name | Value |
+-----------------+-------+
| event_scheduler | OFF |
+-----------------+-------+
1 row in set (0.01 sec)

开启:

SET GLOBAL event_scheduler=on;

(5)存储过程中定义的变量不能和数据表中的字段名重名,不然取不到值。

(6)查看调度器线程:show processlist;

(7)在存储过程中这样定义变量:DECLARE order_id int DEFAULT 0;

(8)当存在多个数据需要循环时,可以用到游标,

  //创建游标,并存储数据
  declare user_data  CURSOR for
    select id,name from user where id<10;

  //创建变量,标识游标是否结束
  declare done INT DEFAULT 0;

  //当游标中的内容执行完后将done设置为1,说明循环游标结束
  declare CONTINUE HANDLER FOR NOT FOUND SET done=1;
  //打开游标
  open user_data;
  //执行循环

  read_loop:LOOP

  //判断是否结束循环
  IF done=1 THEN

    LEAVE read_loop;//跳出循环  
  END IF;
    //取游标中的值
    FETCH user_data into user_id,user_name;
    //执行增删改查操作
    insert ...;

    delete ...;

    update ...;

    select ...;

  END LOOP read_loop;
  //释放游标
  CLOSE user_data;


Mysql中event事件的入门的更多相关文章

  1. mysql中event的用法详解

    一.基本概念mysql5.1版本开始引进event概念.event既“时间触发器”,与triggers的事件触发不同,event类似与linux crontab计划任务,用于时间触发.通过单独或调用存 ...

  2. MySQL中存储过程+事件的使用方法

    一.背景 将界面操作日志存储在MySQL数据库中的operationlog表中,如果该表不能自动备份,表中的数据会越来越多,影响速度.可以定期将表中数据备份到另外一个表中来解决. 二.解决方案 1.使 ...

  3. mysql定时任务(event事件)

    1.event事件 事件(event)是MySQL在相应的时刻调用的过程式数据库对象.一个事件可调用一次,也可周期性的启动,它由一个特定的线程来管理的,也就是所谓的“事件调度器” 事件和触发器类似,都 ...

  4. 记录-MySQL中的事件调度Event Scheduler

    下面是自己的实例 /*查询event是否开启(查询结果Off为关闭 On为开启)*/show variables like '%sche%'; /*开启/关闭命令(1开启--0关闭)*/set glo ...

  5. 【MySQL】Event事件与游标

    MySQL的事件就像Linux系统上的定时任务,按照设置的时间或者间隔时间执行设置好的任务. 如果用SQLyog一类的写存储过程.触发器或者事件会省事一些,例如SQLyog就会生成一个大致的模板: D ...

  6. MySql中的事件

    一.前言 自MySQL5.1.0起,增加了一个非常有特色的功能–事件调度器(Event Scheduler),可以用做定时执行某些特定任务(例如:删除记录.对数据进行汇总等等),来取代原先只能由操作系 ...

  7. mysql定时任务(event事件)

    1.事件简介 事件(event)是MySQL在相应的时刻调用的过程式数据库对象.一个事件可调用一次,也可周期性的启动,它由一个特定的线程来管理的,也就是所谓的“事件调度器”. 事件和触发器类似,都是在 ...

  8. Mysql 中的事件//定时任务

    什么是事件 一组SQL集,用来执行定时任务,跟触发器很像,都是被动执行的,事件是因为时间到了触发执行,而触发器是因为某件事件(增删改)触发执行: 开启事件 查看是否开启: show variables ...

  9. mysql的event(事件)用法详解

    SELECT * FROM mysql.event;SET GLOBAL event_scheduler = 1; -- 开启定时器 0:off 1:on SHOW VARIABLES LIKE 'e ...

随机推荐

  1. 清空mysql数据

    delete from 表名; truncate table 表名; 不带where参数的delete语句可以删除mysql表中所有内容,使用truncate table也可以清空mysql表中所有内 ...

  2. Input 输入框

    Input 输入框 通过鼠标或键盘输入字符 <el-input v-model="input" placeholder="请输入内容"></e ...

  3. Typography 字体

    Typography 字体 我们对字体进行统一规范,力求在各个操作系统下都有最佳展示效果. ¶中文字体 和畅惠风 PingFang SC 和畅惠风 Hiragino Sans GB 和畅惠风 Micr ...

  4. Jmeter(九)集合点

    性能测试需要模拟大量用户并发,集合点能够尽量让虚拟用户同一时刻发送请求, 在Jmeter中集合点是通过定时器-同步定时器来完成的.

  5. 无界面上(linux)运行jmeter(2)

    无界面上(linux)运行jmeter 1.先在bin目录下面创建一个文件夹testplan用来存放脚本(.jmx文件),然后在创建一个文件夹testresult用来存放脚本执行后的结果(.jtl文件 ...

  6. 递归选中easyui树

    $(function(){ // var data1 = [ // { // "id": 3, // "text": "3组织", // & ...

  7. PPT添加节

    如果你要做很多PPT,而又不想把PPT分到很多个文件里,你可以在PPT中添加节(Section).这样你的PPT就像书本一样,一章一章的,非常方便.

  8. Flume采集日志

    角色 Source 数据来源 (exec, kafka, http…)Channel 数据通道 (memory,file,jdbc)Sink 数据目的地 (kafka,hdfs,es…) Agent ...

  9. Pytorch笔记 (3) 科学计算1

    一.张量 标量 可以看作是  零维张量 向量 可以看作是  一维张量 矩阵 可以看作是  二维张量 继续扩展数据的维度,可以得到更高维度的张量 ————>  张量又称 多维数组 给定一个张量数据 ...

  10. python目录和引用关系

    这是我的项目目录 像这样引用没有直接画横线   但是运行时会报错:找不到 typeidea.typeidea.文件路径 图片拖出来看更清晰 后期补充: 解决方案: 如:右击:typeidea----- ...