美文网首页
mysql 使用 Navicat 创建事件 (event) 定时

mysql 使用 Navicat 创建事件 (event) 定时

作者: shmaur | 来源:发表于2019-01-20 03:39 被阅读92次

    DATE_SUB() 函数

    DATE_SUB()   //函数从日期减去指定的时间间隔。
    DATE_SUB(date,INTERVAL expr type)  //语法
    

    type 参数

    MICROSECOND
    SECOND
    MINUTE
    HOUR
    DAY
    WEEK
    MONTH
    QUARTER
    YEAR
    SECOND_MICROSECOND
    MINUTE_MICROSECOND
    MINUTE_SECOND
    HOUR_MICROSECOND
    HOUR_SECOND
    HOUR_MINUTE
    DAY_MICROSECOND
    DAY_SECOND
    DAY_MINUTE
    DAY_HOUR
    YEAR_MONTH

    CURDATE() 函数

    CURDATE()  // 函数返回当前的日期。
    SELECT NOW(),CURDATE(),CURTIME() 
    //例子NOW()                CURDATE()  CURTIME()
    //2008-12-29 16:25:46   2008-12-29  16:25:46
    

    # interval()函数

            INTERVAL() 函数进行比较列表 (N,N1,N2,N3 等等)中的 N 值。该函数如果 N<N1 返回 0,如果 N<N2 返回 1,如果N<N3返回2等等。如果NNULL,它将返回-1。列表值必须是N1<N2<N3的形式才能正常工作。下面的代码是显示INTERVAL()` 函数如何工作的一个简单的例子:

    SELECT NOW()-INTERVAL 24 HOUR 
    

    if exists和if not exists

    if not exists 即如果不存在,if exists 即如果存在

            使用

        1.判断数据库不存在时 
      if not exists(select * from sys.databases where name = ‘database_name’)
    
      2.判断表不存在时 
      if not exists (select * from sysobjects where id = object_id(‘table_name’) and OBJECTPROPERTY(id, ’IsUserTable’) = 1)
    
      3.判断列不存在 
      if not exists (select * from syscolumns where id=object_id(’table_name’) and name=’column_name’)
    

    开始创建事件

    创建事件

    条件:

    delete FROM userInfo WHERE find_Data<DATE_SUB(CURTIME(),INTERVAL 24 HOUR)
    //删除超过24小时前的数据
    
    设置
    定义者

            指定当在事件运行时检查访问权限要使用的用户帐号。默认定义者值是运行 CREATE EVENT 语句的的用户。(这是和 DEFINER = CURRENT_USER 相同。)如果给予一个用户值,它应该是一个 ‘user_name‘@‘host_name‘ 格式的 MySQL 帐号(使用在 GRANT 语句相同的格式)。user_namehost_name 值都是必须的。

    状态

            你可以创建一个事件但可以用 DISABLE 关键字保持不激活。或者,你可以用 ENABLE 来出明确默认状态,这是激活。

    ON COMPLETION

            正常情况下,一旦事件已过期,它将立即删除。你可以通过指定 ON COMPLETION PRESERVE 来重写此性能。使用 ON COMPLETION NOT PRESERVE 只是使默认非持久性的性能明确。

    计划
    AT

            AT timestamp 用于一次性事件。它指定该事件只运行一次于 timestamp 的日期和时间,它必须同时包含日期和时间,或必须是一个解析为 datetime 值的表达式。使用 +INTERVAL 来创建一个事件,它发生在与当前日期和时间有关的将来某个时候。

    EVERY

            在定期间隔重复的行动,你可以用一个 EVERY 子句之后是一个 interval。(+INTERVALEVERY 不能同时使用。)

    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 相当于「每十二个小时,从现在起三十分钟后开始,并于现在起四个星期后结束」。

    timestamp 必须在未来的 - 你不能安排一个事件发生在过去。
    interval 区间由两部份组成,数量和时间单位。

    保存

             最后点击保存就行

    相关文章

      网友评论

          本文标题:mysql 使用 Navicat 创建事件 (event) 定时

          本文链接:https://www.haomeiwen.com/subject/caitjqtx.html