zoukankan      html  css  js  c++  java
  • 用MySQL创建定时任务

    -- 查看有哪些定时计划
    show events
    -- 删除名称为risk的定时计划
    DROP EVENT IF EXISTS risk;
    -- 创建定时计划的例子,每天定时,自动将日期加1天
    CREATE EVENT `risk_spider_crawl_param_update`
    ON SCHEDULE EVERY 1 DAY STARTS '2020-03-13 01:30:00'
    ON COMPLETION PRESERVE
    ENABLE
    DO
    update risk_spiders_crawl_param set start_date=CURRENT_DATE, end_date = date(CURRENT_DATE + 1) ;

    可以用navicat创建事件,更快捷:

    Navicat创建和设计MySQL事件

    1.开启定时器 0:off 1:on
     SET GLOBAL event_scheduler = 1;
    2.在navicat左侧选择一个数据库,单击“时间”-“创建事件”,弹出一个窗口。

    在定义选项输入SQL语句,以BEGIN开头,以END结尾。
    如果是在本地运行,Definer为root@localhost。
    3.计划任务,每隔一段时间就有固定需求的操作,如创建表,删除数据等操作。

    3-1. AT 时间戳,用来完成单次的计划任务。
    3-2. EVERY 时间(单位)的数量时间单位[STARTS 时间戳] [ENDS时间戳],用来完成重复的计划任务。时间单位较多,按需选择。
    在两种计划任务中,时间戳可以是任意的TIMESTAMP 和DATETIME 数据类型,时间戳需要大于当前时间。
    最后保存就OK了

    附上mysql事件的语法:
    MySQL 或 MariaDB 事件语法
    MySQL 事件计划是在 MySQL 5.1.6 添加。MySQL 事件是按计划运行工作。因此,我们有时称它们为计划事件。当你创建一个事件时,你是创建一个有名的数据库对象,包含在一个或多个规律区间运行一个或多个 SQL 语句,并在特定的日期时间开始及结束。从概念上,这是类似 Windows 任务计划程序的概念。点击  来打开 事件 的对象列表。
    定义
    定义包括一个有效的 SQL 语句。这可以是一个简单的语句,如 SELECT 或 INSERT,或它可以是一个用 BEGIN 和 END 写的复合语句。复合语句可以包含声明循环和其它控制结构语句。
    提示:要自定义编辑器的视图并查看更多 sql 编辑功能,请看编辑器高级功能。
    定义者
      指定当在事件运行时检查访问权限要使用的用户帐号。默认定义者值是运行 CREATE EVENT 语句的的用户。(这是和 
    DEFINER = CURRENT_USER 相同。)如果给予一个用户值,它应该是一个 ‘user_name‘@‘host_name‘ 格式的 
    MySQL 帐号(使用在 GRANT 语句相同的格式)。user_name 及 host_name 值都是必须的。
    状态
      你可以创建一个事件但可以用 DISABLE 关键字保持不激活。或者,你可以用 ENABLE 来出明确默认状态,这是激活。
    ON COMPLETION
      正常情况下,一旦事件已过期,它将立即删除。你可以通过指定 ON COMPLETION PRESERVE 来重写此性能。使用 ON COMPLETION NOT PRESERVE 只是使默认非持久性的性能明确。
    计划
    AT
      AT timestamp 用于一次性事件。它指定该事件只运行一次于 timestamp 的日期和时间,它必须同时包含日期和时间,或必须是一个解析为 datetime 值的表达式。使用 +INTERVAL 来创建一个事件,它发生在与当前日期和时间有关的将来某个时候。
    EVERY
      在定期间隔重复的行动,你可以用一个 EVERY 子句之后是一个 interval。(+INTERVAL 与 EVERY 不能同时使用。)
    STARTS
      EVERY 子句还可能包含一个非必须的 STARTS 子句。STARTS 之后是一个 timestamp 值表示行动应该何时开始重复,也可以用 +INTERVAL 间隔以指定「由现在开始」的时间量。
    例如:EVERY 3 MONTH STARTS CURRENT_TIMESTAMP + 1 WEEK 的意思是「每 3 个月,从现在起一周后开始」。
    ENDS 
      EVERY 子句还可包含一个非必须的 ENDS 子句。ENDS 关键字之后是一个 timestamp 值告诉 MySQL 何时停止重复事件。你也可以用 +INTERVAL 间隔与 ENDS 一起。
    例如:EVERY 12 HOUR STARTS CURRENT_TIMESTAMP + INTERVAL 30 MINUTE ENDS CURRENT_TIMESTAMP + INTERVAL 4 WEEK 相当于「每十二个小时,从现在起三十分钟后开始,并于现在起四个星期后结束」。


    P.S. 
    timestamp 必须在未来的 - 你不能安排一个事件发生在过去。

    interval 区间由两部份组成,数量和时间单位*。
          *YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE |
          WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE |
          DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND 

    来自:http://mysql.zhizuobiao.com/mysql-18081600248/

  • 相关阅读:
    位运算
    (二)给Centos配置网络以及使用xshell远程连接Centos
    (一)安装Linux时的磁盘划分
    (五)多点触控之兼容ViewPager
    (四)双击放大与缩小图片
    (三)多点触控之自由移动缩放后的图片
    (二)弥补图片自由缩放出现的间隙
    (一)自定义ImageView,初步实现多点触控、自由缩放
    (四)实现菜单点击弹出提示框
    (三)实现菜单点击动画
  • 原文地址:https://www.cnblogs.com/yoyowin/p/12470149.html
Copyright © 2011-2022 走看看