最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

mysql如何定时任务

来源:懂视网 责编:小采 时间:2020-11-09 15:17:01
文档

mysql如何定时任务

mysql如何定时任务:1,需求:每天晚上10点到早上5点,每10分钟定时执行存储过程。2,实现方式:实现方式有两种: 一种是比较常规的,用mysql的event定时任务,先介绍一下mysql中event定时任务的相关命令,查看event是否启用:SELECT @@event_scheduler; SH
推荐度:
导读mysql如何定时任务:1,需求:每天晚上10点到早上5点,每10分钟定时执行存储过程。2,实现方式:实现方式有两种: 一种是比较常规的,用mysql的event定时任务,先介绍一下mysql中event定时任务的相关命令,查看event是否启用:SELECT @@event_scheduler; SH

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_ALARM
 ON SCHEDULE EVERY 10 MINUTE
DO
 BEGIN
 if(date_format(current_time(),'%H')>22 || date_format(current_time(),'%H')<5) THEN
 CALL PRO_ALARM();
 END IF;
END

建立存储过程:

DROP PROCEDURE IF EXISTS PRO_ALARM;
CREATE PROCEDURE PRO_ALARM()
 BEGIN
 DECLARE userId VARCHAR(32);

 #这个用于处理游标到达最后一行的情况
 DECLARE s INT DEFAULT 0;

 #声明游标cursor_name(cursor_name是个多行结果集)
 DECLARE cursor_data CURSOR FOR
 SELECT tmp.USER_ID
 FROM (
 SELECT
 e.USER_ID,
 MAX(e.TIME_GMT) TIME_GMT
 FROM EVENTS e
 GROUP BY e.USER_ID
 HAVING MAX(e.TIME_GMT) < UNIX_TIMESTAMP() - 60 * 30
 AND MAX(e.TIME_GMT) > UNIX_TIMESTAMP() - 60 * 60 * 24) tmp
 INNER JOIN EVENTS t ON tmp.USER_ID = t.USER_ID
 AND tmp.TIME_GMT = t.TIME_GMT
 WHERE TYPE_ID != '34001';

 #设置一个终止标记
 DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET s = 1;

 OPEN cursor_data;

 #获取游标当前指针的记录,读取一行数据并传给变量a,b
 FETCH cursor_data
 INTO userId;

 #开始循环,判断是否游标已经到达了最后作为循环条件
 WHILE s <> 1 DO
 INSERT INTO EVENTS_NOTIFICATION VALUES (NULL, SYSDATE(), UNIX_TIMESTAMP(SYSDATE()),
 UNIX_TIMESTAMP(SYSDATE()), '00000', userId, '1', '0');
 #读取下一行的数据
 FETCH cursor_data
 INTO 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视频教程

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

mysql如何定时任务

mysql如何定时任务:1,需求:每天晚上10点到早上5点,每10分钟定时执行存储过程。2,实现方式:实现方式有两种: 一种是比较常规的,用mysql的event定时任务,先介绍一下mysql中event定时任务的相关命令,查看event是否启用:SELECT @@event_scheduler; SH
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top