gpt4 book ai didi

Oracle DBMS_Scheduler 周末频率变化

转载 作者:行者123 更新时间:2023-12-04 09:14:23 24 4
gpt4 key购买 nike

我创建了一个 oracle dbms 调度程序,每天在早上 5 点、上午 10 点、下午 3 点和晚上 8 点执行一个过程。下面是调度程序代码

DBMS_SCHEDULER.CREATE_JOB
(
job_name => 'TEST_JOB'
,start_date => SYSDATE
,repeat_interval => 'FREQ=DAILY; BYHOUR=05,10,15,20; BYMINUTE=00 ;BYSECOND=0;'
,end_date => NULL
,job_class => 'DEFAULT_JOB_CLASS'
,job_type => 'PLSQL_BLOCK'
,enabled => TRUE
,job_action => 'BEGIN INSERT_IN_TABLE; END;'
,comments => 'TEST JOB'
);
现在我必须修改相同的调度程序才能在周末只执行两次相同的程序,并在工作日以相同的频率运行。
我不想为周末执行创建不同的调度程序,因为有时该过程需要 5 多个小时才能执行。
如果有更好的方法来实现这一点,请指导我。

最佳答案

一种选择是使用嵌入式日历,以便您可以创建自己的日历表达式。
让我给你看一个例子

SQL> BEGIN
dbms_scheduler.create_schedule('my_schedule_c_1', repeat_interval =>
'FREQ=DAILY; BYHOUR=05,10,15,20; BYMINUTE=00; BYSECOND=00; ');
dbms_scheduler.create_schedule('my_schedule_c_2', repeat_interval =>
'FREQ=DAILY; BYDAY=SAT,SUN; BYHOUR=05,10; BYMINUTE=00; BYSECOND=00;');
END;
/ 2 3 4 5 6 7

PL/SQL procedure successfully completed.

SQL> begin
DBMS_SCHEDULER.create_schedule ('MY_CALC', repeat_interval =>'my_schedule_c_1, my_schedule_c_2');
END;
/ 2 3 4

PL/SQL procedure successfully completed.

SQL>
然后,您只需要将这个时间表应用到您的工作中。
SQL> begin
2 DBMS_SCHEDULER.CREATE_JOB
(
job_name => 'TEST_JOB'
,start_date => SYSDATE
3 ,repeat_interval => 'MY_CALC'
4 ,end_date => NULL
,job_class => 'DEFAULT_JOB_CLASS'
,job_type => 'PLSQL_BLOCK'
5 6 7 8 9 10 ,enabled => TRUE
,job_action => 'BEGIN NULL; END;'
,comments => 'TEST JOB'
); 11 12 13
14 end;
15 /

PL/SQL procedure successfully completed.

SQL>
这样,我的工作将使用 MAIN_CALC 计划运行,它是两种不同频率的组合。
当然,您始终可以创建两个作业,但在 11g 中没有创建不兼容性的选项,这是 DBMS_SCHEDULER 12c 以后的一个对象,它阻止一个作业在另一个完成之前启动。
我的建议,使用嵌入多个频率的日程表

关于Oracle DBMS_Scheduler 周末频率变化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63279854/

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