mysql定时任务的实现
1,需求:每天晚上10点到早上5点,每10分钟定时执行存储过程。
2,实现方式:实现方式有两种:
一种是比较常规的,用mysql的event定时任务,先介绍一下mysql中event定时任务的相关命令,
查看event是否启用:
SELECT @@event_scheduler;
SHOW VARIABLES LIKE 'event%';
开启定时任务:
set GLOBAL event_scheduler = 1;
SET GLOBAL event_scheduler = ON;
建立定时任务:
DROP EVENT IF EXISTS JOB_ALARM;
CREATE EVENT JOB_ALARMON SCHEDULE EVERY 10 MINUTE
DOBEGINif(date_format(current_time(),'%H')>22 || date_format(current_time(),'%H')<5) THENCALL PRO_ALARM();END IF;
END
建立存储过程:
DROP PROCEDURE IF EXISTS PRO_ALARM;
CREATE PROCEDURE PRO_ALARM()BEGINDECLARE userId VARCHAR(32);#这个用于处理游标到达最后一行的情况DECLARE s INT DEFAULT 0;#声明游标cursor_name(cursor_name是个多行结果集)DECLARE cursor_data CURSOR FORSELECT tmp.USER_IDFROM (SELECTe.USER_ID,MAX(e.TIME_GMT) TIME_GMTFROM EVENTS eGROUP BY e.USER_IDHAVING MAX(e.TIME_GMT) < UNIX_TIMESTAMP() - 60 * 30AND MAX(e.TIME_GMT) > UNIX_TIMESTAMP() - 60 * 60 * 24) tmpINNER JOIN EVENTS t ON tmp.USER_ID = t.USER_IDAND tmp.TIME_GMT = t.TIME_GMTWHERE TYPE_ID != '34001';#设置一个终止标记DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET s = 1;OPEN cursor_data;#获取游标当前指针的记录,读取一行数据并传给变量a,bFETCH cursor_dataINTO userId;#开始循环,判断是否游标已经到达了最后作为循环条件WHILE s <> 1 DOINSERT INTO EVENTS_NOTIFICATION VALUES (NULL, SYSDATE(), UNIX_TIMESTAMP(SYSDATE()),UNIX_TIMESTAMP(SYSDATE()), '00000', userId, '1', '0');#读取下一行的数据FETCH cursor_dataINTO userId;END WHILE;#关闭游标CLOSE cursor_data;END;
在配置定时器时有一些局限性,并且由于博主使用的mysql启用了skip-grant-tables,在设置event开启时,总是报错,所以想到了第二种实现方式,具体报错信息如下:
[HY000][1290] The MySQL server is running with the --event-scheduler=DISABLED or --skip-grant-tables option so it cannot execute this statement
第二种实现方式是利用linux的定时任务,
linux定时任务基本命令:
查看定时任务:crontab -l
编辑定时任务:crontab -e
*/10 22-23,0-5 * * * mysql -u用户名 -p密码 -e "use db_name;CALL PRO_ALARM();"
或者把use db_name;CALL PRO_ALARM();存到sql脚本中,编辑定时任务如下:
*/10 22-23,0-5 * * * mysql -u用户名 -p密码 < /application/Job_mysql.sql
mysql定时任务的实现相关推荐
- linux设置mysql定时任务_原创 Linux下实现Mysql定时任务备份数据
本实例将创建目录放置于/mnt目录下,可根据具体情况放置于其他目录: cd /mnt mkdir dbback pwd /mnt/dbback 创建shell脚本 脚本名称可根据自己规范进行自定义: ...
- MySQL定时任务event,储存过程(定时删除指定时间前90天指定表的数据)
<span style="font-family: 'Microsoft YaHei'; font-size: 14px;">MySQL定时任务event</sp ...
- linux mysql 定时任务_Linux下Mysql定时任务备份数据的实现方法
前言 备份是容灾的基础,是指为防止系统出现操作失误或系统故障导致数据丢失,而将全部或部分数据集合从应用主机的硬盘或阵列复制到其它的存储介质的过程.而对于一些网站.系统来说,数据库就是一切,所以做好数据 ...
- navicat创建MySql定时任务详解
目录 navicat创建MySql 定时任务详解 一.开起定时任务 二.通过navicat创建定时任务 三.关闭.启动.别名.移动.删除event 四.查询Event信息 navicat创建MySql ...
- mysql定时任务 每日执行存储过程
原文链接:mysql定时任务 每日执行存储过程 1.操作工具Navicat数据库操作工具. 2.创建一个存储过程 例如:delete From apply_setdtl where DATE(crea ...
- navicat创建mysql定时任务_navicat创建MySql定时任务的方法详解
navicat创建MySql 定时任务详解 事件(event)是MySQL在相应的时刻调用的过程式数据库对象.一个事件可调用一次,也可周期性的启动,它由一个特定的线程来管理的,也就是所谓的" ...
- linux设置mysql定时任务_Linux下如何实现Mysql定时任务
假设前提:每天晚上10点到早上5点,每10分钟定时执行存储过程. 实现方式: 第一种是利用mysql本身实现,制定event定时任务,可以借助navicat for mysql或其他数据库开发工具去做 ...
- Navicat设定mysql定时任务!
Navicat设定mysql定时任务! 需求:每天将一张表的前一天的数据抽取到另一张表中,使用Mysql数据库的客户端Navicat配置 第一步,创建过程cust_report,直接在查询窗口中执 ...
- navicat mysql 计划任务_navicat创建MySql定时任务的方法详解
navicat创建MySql 定时任务详解 事件(event)是MySQL在相应的时刻调用的过程式数据库对象.一个事件可调用一次,也可周期性的启动,它由一个特定的线程来管理的,也就是所谓的" ...
- tp5 mysql定时任务_tp5+mysql实现消息队列,并在mac系统下定时执行-Go语言中文社区...
Demo简介 订单系统和配货系统之间的信息传递,当订单系统压力比较大时或者出现故障时不影响到配货系统,所以就用了消息队列和定时系统. Demo准备 1.创建一张数据表重点内容 status:0未处理, ...
最新文章
- python学起来难不难-新手学python数据分析难不难?
- python就业方向及工资-Python的5大就业方向,薪资诱人前景好!
- eclipse 如何忽略js文件报错
- GitHub上个最有意思的项目合集(技术清单系列)
- 高阶篇:8.1)开模前评审及提交资料;
- android访问百度新闻,百度新闻(com.baidu.news) - 8.3.6.0 - 应用 - 酷安
- Nginx源码分析-启动初始化过程(一)
- intellij idea jdk language level
- 大小文件服务器区别,在提供静态包时,观察到Nginx和Express服务器之间文件大小的差异...
- docker搭建lnmp环境
- windows的回车换行“\r\n“,Linux的回车换行“\n“
- Java面试题超详细讲解系列之四【Jvm篇】
- 编程基本功:正常运行的代码,你看明白能做什么?不如解决几个简单BUG
- 谷歌大脑的“世界模型”简述与启发
- 卷积神经网络之“浅层特征”与“深层特征”
- 上位机软件定制开发,如何选择服务商
- 计算机29首流行音乐叫什么,2018结婚用的歌曲排名 50首流行歌曲燃爆婚礼现场...
- 常用的办公软件有哪些?
- php mysql函数未定义,关于php:Wierd和Annoying错误:调用未定义的函数mysql_query()...
- MP | 东农吴凤芝/南农韦中-根系分泌物介导的植物种间互作塑造了根际微生物组抑病力...
热门文章
- linux下脚本录制工具——script和scriptreplay
- 即将升级的LDK7.1支持云授权了
- 推荐 2 个 Spring Boot 工作流项目,轻松搞定工作流!
- 百度指数+SEO+博客 菜鸟站长的黄金搭档
- 第23次CSP认证(202109)
- appinventor mysql_利用AppInventor实现登录功能(完整版).docx
- JS--利用setTimeout模拟setInterval
- 机器学习【逻辑回归】——logistic函数逻辑回归鸢尾花分类
- java 虚拟机(3)
- 英语论文写作词汇积累20161101