Mysql中event事件的入门
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事件的入门的更多相关文章
- mysql中event的用法详解
一.基本概念mysql5.1版本开始引进event概念.event既“时间触发器”,与triggers的事件触发不同,event类似与linux crontab计划任务,用于时间触发.通过单独或调用存 ...
- MySQL中存储过程+事件的使用方法
一.背景 将界面操作日志存储在MySQL数据库中的operationlog表中,如果该表不能自动备份,表中的数据会越来越多,影响速度.可以定期将表中数据备份到另外一个表中来解决. 二.解决方案 1.使 ...
- mysql定时任务(event事件)
1.event事件 事件(event)是MySQL在相应的时刻调用的过程式数据库对象.一个事件可调用一次,也可周期性的启动,它由一个特定的线程来管理的,也就是所谓的“事件调度器” 事件和触发器类似,都 ...
- 记录-MySQL中的事件调度Event Scheduler
下面是自己的实例 /*查询event是否开启(查询结果Off为关闭 On为开启)*/show variables like '%sche%'; /*开启/关闭命令(1开启--0关闭)*/set glo ...
- 【MySQL】Event事件与游标
MySQL的事件就像Linux系统上的定时任务,按照设置的时间或者间隔时间执行设置好的任务. 如果用SQLyog一类的写存储过程.触发器或者事件会省事一些,例如SQLyog就会生成一个大致的模板: D ...
- MySql中的事件
一.前言 自MySQL5.1.0起,增加了一个非常有特色的功能–事件调度器(Event Scheduler),可以用做定时执行某些特定任务(例如:删除记录.对数据进行汇总等等),来取代原先只能由操作系 ...
- mysql定时任务(event事件)
1.事件简介 事件(event)是MySQL在相应的时刻调用的过程式数据库对象.一个事件可调用一次,也可周期性的启动,它由一个特定的线程来管理的,也就是所谓的“事件调度器”. 事件和触发器类似,都是在 ...
- Mysql 中的事件//定时任务
什么是事件 一组SQL集,用来执行定时任务,跟触发器很像,都是被动执行的,事件是因为时间到了触发执行,而触发器是因为某件事件(增删改)触发执行: 开启事件 查看是否开启: show variables ...
- mysql的event(事件)用法详解
SELECT * FROM mysql.event;SET GLOBAL event_scheduler = 1; -- 开启定时器 0:off 1:on SHOW VARIABLES LIKE 'e ...
随机推荐
- React之父子组件之间传值
1.新增知识点 /** React中的组件: 解决html 标签构建应用的不足. 使用组件的好处:把公共的功能单独抽离成一个文件作为一个组件,哪里里使用哪里引入. 父子组件:组件的相互调用中,我们把调 ...
- hash模块MD5加密
MD5加密:获取32位加密字符串: 示例(MD5加密'123456')import hashlibhashObject=hashlib.md5(b'123456') #实例化,加密字符串不能直接加密, ...
- 前端UI框架搜集
网址:https://blog.csdn.net/will5451/article/details/80652429?utm_source=blogxgwz6 网址:https://www.cnblo ...
- Django模型的Field Types
Field Types 常用参数: null 如果设置为 True , Django 存放一个 NULL 到数据库字段.默认为 False. allow_null 如果设置为 True , 该字段将接 ...
- java并发编程 线程间协作
线程间协作 1. 等待和通知 等待和通知的标准形式 等待方: 获取对象锁 循环中判断条件是否满足,不调用wait()方法 条件满足执行业务逻辑 通知方: 获取对象所 改变条件 通知所有等待在对象的线程 ...
- SpringBoot 和 SpringCloud 之间关系?
SpringBoot:专注于快速方便的开发单个个体微服务(关注微观):SpringCloud:关注全局的微服务协调治理框架,将SpringBoot开发的一个个单体微服务组合并管理起来(关注宏观):Sp ...
- mysql中索引类型
mysql索引类型normal,unique,full text的是什么? normal:表示普通索引 unique:表示唯一的,不允许重复的索引,如果该字段信息保证不会重复例如身份证号用作索引时,可 ...
- vue2.X + HTML5 plus 拍照和调用设备相册 另附 图片转base64和压缩图片方法
HTML5 部分 <button @click="tesCamera()" type="button" :disabled="isshStatu ...
- for循环实现九九乘法表
<!--for循环实现九九乘法表--> <table border="> <tbody> {% for x in range(1,10) %} <t ...
- tableau单机版安装
参考: https://help.tableau.com/current/server-linux/zh-cn/requ.htm 先将服务器防火墙80级8850端口打开 临时关闭SELinux/防 ...