gpt4 book ai didi

oracle12c - Oracle dbms_scheduler 与 BYTIME 错误

转载 作者:行者123 更新时间:2023-12-02 22:49:56 24 4
gpt4 key购买 nike

我试图让作业在每个工作日(周一至周六)上午 6:30 运行,但 Oracle 调度程序拒绝了

ORA-27419 "unable to determine valid execution date from repeat interval"

当我发现以下行为时,我开始失去理智:

首先,创建一个虚拟作业。请注意,它没有时间表并且未启用。

BEGIN
DBMS_SCHEDULER.CREATE_JOB (
job_name => '"TMP_DUMMY"',
job_type => 'PLSQL_BLOCK',
job_action => 'begin
dbms_lock.sleep(5);
end;',
number_of_arguments => 0,
start_date => NULL,
end_date => NULL,
enabled => FALSE,
auto_drop => FALSE,
comments => 'Test Job');




DBMS_SCHEDULER.SET_ATTRIBUTE(
name => '"TMP_DUMMY"', attribute => 'store_output', value => TRUE);
DBMS_SCHEDULER.SET_ATTRIBUTE( name => '"TMP_DUMMY"', attribute => 'logging_level', value => DBMS_SCHEDULER.LOGGING_OFF);

END;
/

下一步,使用 BYTIME 设置一个重复间隔,其中任何执行时间等于或小于整小时后的 02:55 (MI:SS)。无论是否带有小时部分,这并不重要,对于前一个选项,确切的小时也并不重要。

BEGIN
DBMS_SCHEDULER.set_attribute( name => '"TMP_DUMMY"', attribute => 'repeat_interval', value => 'FREQ=DAILY;BYTIME=010255');
DBMS_SCHEDULER.enable(name=>'"TMP_DUMMY"');
END;
/

这对我来说非常有效。

现在我想将 BYTIME 增加 1 秒至 02:56 (MI:SS)

BEGIN
DBMS_SCHEDULER.set_attribute( name => '"TMP_DUMMY"', attribute => 'repeat_interval', value => 'FREQ=DAILY;BYTIME=010256');
END;
/

运行此属性更改我得到

ORA-27470: failed to re-enable "[schema]"."TMP_DUMMY" after making requested change ORA-27419: unable to determined valid execution date from repeat interval

我已经验证了所有 MI:SS 组合的此行为:

set serveroutput on
DECLARE
l_rep_interval VARCHAR2(50 CHAR);
BEGIN
FOR mi IN 0..59
LOOP
FOR ss IN 0..59
LOOP
l_rep_interval := 'FREQ=DAILY;BYTIME='||lpad(to_char(mi*100+ss),4,'0');
DBMS_SCHEDULER.set_attribute( name => '"TMP_DUMMY"', attribute => 'repeat_interval', value => l_rep_interval);
DBMS_SCHEDULER.enable(name=>'"TMP_DUMMY"');
DBMS_OUTPUT.PUT_LINE(l_rep_interval);
END LOOP; --end ss
END LOOP; --end mi

EXCEPTION WHEN OTHERS THEN NULL;

END;
/

它从 00:00 到 02:55 正常工作,在所有其他时间都失败。对我来说,这看起来像 MI:SS 部分被视为tinyint,更高的值会导致类型溢出。

这是调度程序中的错误还是我在这里遗漏了一些东西?Oracle版本是12c。

最佳答案

我刚刚遇到了同样的问题。看起来(从文档来看)BYTIME 无法识别(即使 SQLDeveloper 在您查看作业 GUI 的 SQL 选项卡时使用它)

我发现使用 BYMinute 和 ByHour 可以实现以下效果

DBMS_SCHEDULER.set_attribute( name => '"TEST"."JOB"', attribute => 'repeat_interval', value => 'FREQ=DAILY;BYHOUR=9;BYMINUTE=30;BYDAY=MON,TUE,WED ,周四,周五,周六,周日');

希望这对某人有帮助。

关于oracle12c - Oracle dbms_scheduler 与 BYTIME 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43981300/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com