zoukankan      html  css  js  c++  java
  • mysql定时器,定时查询数据库,把查询结果插入到一张表中 阿星小栈

     
     
    1、有两张表order_repayment_detail,msg_sim ,需要把前者中的按时间过滤出来的信息插入到短信发送表中,可以每晚12点钟查询执行一次查询。

    创建存储过程,这里的存储过程主要提供给mysql的定时器event来调用去执行:
    create procedure mypro()
    BEGIN

    INSERT INTO `msg_sim` ( `tel`, `msg_content`, `title`, `msg_status`, `source`, `is_deleted`, `gmt_create`, `gmt_modified`)
    SELECT t.user_mobile, CONCAT("您有一笔", d.amount,"元账单须3天后还款!") as content ,"账单3天时提醒",1,1,0 ,SYSDATE(),SYSDATE() FROM
    order_repayment_detail d LEFT JOIN `order_info` t on t.order_no=d.order_no where d.bill_status!=2 and datediff(d.due_time,now())=3;

    end;


    紧接着创建mysql的定时器event:
    create event if not exists eventJob 
    on schedule every 1 second 
    on completion PRESERVE
    do call mypro();
    这里设置为每一秒执行一次  ,可以在事件设计中修改计划


    至此所有的准备工作已经写完了,做完这些,mysql要想利用定时器必须的做准备工作,就是把mysql的定时器给开启了:
    SET GLOBAL event_scheduler = 1;  -- 启动定时器
    SET GLOBAL event_scheduler = 0;  -- 停止定时器


    紧接着还要开启事件:
    ALTER EVENT eventJob ON  COMPLETION PRESERVE ENABLE;   -- 开启事件
    ALTER EVENT eventJob ON  COMPLETION PRESERVE DISABLE;  -- 关闭事件


    SHOW VARIABLES LIKE '%sche%'; -- 查看定时器状态


    至此,你去数据库里面的表mytable里面看下,系统会每隔一秒去插入一条数据,嘻嘻,任务完成了。
    select * from msg_sim
     
    转:http://www.cnblogs.com/likun10579/p/6909362.html
  • 相关阅读:
    DDOS攻击
    定时器任务:Timer跟ScheduledExecutorService
    11、分布式Dubbo+Zokeeper+SpringBoot
    10、springboot中的任务:异步任务、邮件发送、定时任务
    PHP算法之最长公共前缀
    PHP算法之罗马数字转整数
    PHP算法之整数转罗马数字
    PHP-SQL查询上升的温度
    PHP算法之统计全为 1 的正方形子矩阵
    PHP算法之增减字符串匹配
  • 原文地址:https://www.cnblogs.com/dereckbu/p/7326168.html
Copyright © 2011-2022 走看看