ALTER EVENT

功能描述

修改已创建的定时任务中的参数。

注意事项

  • 定时任务相关操作只有sql_compatibility = ‘B’时支持。

  • 只有定时任务的所有者有权修改待修改的定时任务,系统管理员默认拥有修改所有定时任务的权限。

  • 可以通过SHOW EVENTS或在PG_JOB表中查看log_user列来获得job的所有者信息

  • 修改定时任务时每次修改成功后会更新被修改job的所有者为当前用户,若修改定时任务时指定了definer,则更新为被指定的definer。

  • definer选项场景限制与CREATE EVENT章节中对definer限制场景一致。

    ALTER EVENT - 图1 须知:

    系统管理员修改其他用户创建的定时任务后,被修改定时任务的所有者将切换为系统管理员,待执行语句将使用系统管理员的权限执行。

语法格式

  1. ALTER
  2. [DEFINER = user]
  3. EVENT event_name
  4. [ON SCHEDULE schedule]
  5. [ON COMPLETION [NOT] PRESERVE]
  6. [RENAME TO new_event_name]
  7. [ENABLE | DISABLE | DISABLE ON SLAVE]
  8. [COMMENT 'string']
  9. [DO event_body]

参数说明

  • definer

    定时任务待执行语句在执行时使用的权限。默认情况下使用当前创建定时任务者的权限,当definer被指定时,使用被指定用户用户权限。

    definer参数只有具有sysadmin权限的用户有权指定。

  • RENAME TO

    更新定时任务名。

  • ON COMPLETION [NOT] PRESERVE

    默认情况下,一旦事务处于完成状态,系统表中就会立刻删除该定时任务。用户可以通过设置ON COMPLETION PRESERVE来覆盖默认行为。

  • ENABLE | DISABLE | DISABLE ON SLAVE

    创建定时任务后,定时任务默认处于ENABLE状态,即到规定时间立即执行待执行语句。用户可以使用DISABLE关键字,改变定时任务的活动状态。DISABLE ON SLAVE表现与DISABLE一致。

  • COMMENT ‘string’

    用户可以给定时任务添加注释,注释内容在GS_JOB_ATTRIBUTE表中查看。

  • event_body

    定时任务待执行语句。

示例

  1. --创建一个定时任务
  2. openGauss=# CREATE TABLE t_ev(num int);
  3. openGauss=# CREATE EVENT IF NOT EXISTS event_e1 ON SCHEDULE AT sysdate + interval 5 second + interval 33 minute DISABLE DO insert into t_ev values(0);
  4. --修改定时任务
  5. openGauss=# ALTER EVENT event_e1 ENABLE DO select 1;
  6. openGauss=# ALTER EVENT event_e1 RENAME TO event_ee;