最新文章专题视频专题问答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
当前位置: 首页 - 科技 - 知识百科 - 正文

Linux下如何实现Mysql定时任务

来源:懂视网 责编:小采 时间:2020-11-09 20:26:20
文档

Linux下如何实现Mysql定时任务

Linux下如何实现Mysql定时任务:假设前提:每天晚上10点到早上5点,每10分钟定时执行存储过程。 实现方式: 第一种是利用Mysql本身实现,制定event定时任务,可以借助Navicat For Mysql或其他数据库开发工具去做; 第二种实现方式是利用linux的定时任务,这个是利用Linux系统自带任务管
推荐度:
导读Linux下如何实现Mysql定时任务:假设前提:每天晚上10点到早上5点,每10分钟定时执行存储过程。 实现方式: 第一种是利用Mysql本身实现,制定event定时任务,可以借助Navicat For Mysql或其他数据库开发工具去做; 第二种实现方式是利用linux的定时任务,这个是利用Linux系统自带任务管

假设前提:每天晚上10点到早上5点,每10分钟定时执行存储过程。

实现方式:

第一种是利用Mysql本身实现,制定event定时任务,可以借助Navicat For Mysql或其他数据库开发工具去做;
第二种实现方式是利用linux的定时任务,这个是利用Linux系统自带任务管理工具实现的。

一、Mysql中event定时任务的相关命令,

1.查看event是否启用:

SELECT @@event_scheduler; 
或
SHOW VARIABLES LIKE 'event%'; 

2.开启定时任务:

set GLOBAL event_scheduler = 1; 
或
SET GLOBAL event_scheduler = ON; 

3.建立定时任务:

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

4.建立存储过程:

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; 

二、利用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

总结

以上所述是小编给大家介绍的Linux下如何实现Mysql定时任务,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

您可能感兴趣的文章:

  • mysql的定时任务实例教程
  • Mysql下自动删除指定时间以前的记录的操作方法
  • 在Windows环境下使用MySQL:实现自动定时备份
  • MySQL数据库Event定时执行任务详解
  • 老生常谈mysql event事件调度器(必看篇)
  • mysql中event的用法详解
  • mysql定时任务(event事件)实现详解
  • 文档

    Linux下如何实现Mysql定时任务

    Linux下如何实现Mysql定时任务:假设前提:每天晚上10点到早上5点,每10分钟定时执行存储过程。 实现方式: 第一种是利用Mysql本身实现,制定event定时任务,可以借助Navicat For Mysql或其他数据库开发工具去做; 第二种实现方式是利用linux的定时任务,这个是利用Linux系统自带任务管
    推荐度:
    标签: 自动 定时 实现
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top